通過 Java 操作 MongoDB
mongodb的java驅動已經提供比較全的操作,分為三塊:
1.普通用戶操作
2.管理員操作
3.oplog操作
具體可以添加一個eclipse testng插件,再在工程中導入testng.jar包即可看到。
本文主要說明各個使用點和注意事項。
1.連接一個復制集(replica sets)mongod:
復制集是mongo解決穩定性的一個方案,也是可以實現讀寫分離的一種實現,這里介紹復制集的java連接方式。
static Mongo m; static { List<ServerAddress> addresslist = new ArrayList<ServerAddress>(); try { addresslist.add(new ServerAddress("127.0.0.1:10240")); addresslist.add(new ServerAddress("127.0.0.1:11240")); addresslist.add(new ServerAddress("127.0.0.1:12240")); } catch (UnknownHostException e) { System.err.println("address check error."); System.exit(-1); } MongoOptions options = new MongoOptions(); options.autoConnectRetry = true; options.connectionsPerHost = 20; options.connectTimeout = 6000; options.maxAutoConnectRetryTime = 12000; options.maxWaitTime = 12000; options.socketKeepAlive = true; options.socketTimeout = 2000; try { m = new Mongo(addresslist, options); } catch (MongoException e) { System.err.println("mongo create error."); System.exit(-1); } }注:一般例子采用的連接方式是直接連一個mongod服務,但是作為單臺的生產環境顯然安全性不足,因此采用復制集方式,連接也區別于一般,是使用
public Mongo( List<ServerAddress> replicaSetSeeds , MongoOptions options ) throws MongoException方法。
MongoOptions根據自己的需求設置,參數說明已經很多了,不細講。
注意mongo實例使用單例模式。
2.獲取db:
DB db = m.getDB("test");注:取到名為test的db進行操作;若該db不存在,該操作會創建對應的db。
3.獲取集合:
DBCollection col = db.getCollection("offer");注:取名字為offer的集合;類似于db的表。
以上三個操作是建立連接,接下去才是db中常用的操作。
4.查詢:
DBCursor cursor = col.find(); while(cursor.hasNext()) { System.out.println(cursor.next()); i++; }注:全集合查詢,輸出每條記錄,正常情況不會作類似操作,記住兩個東西,find()和cursor
BasicDBObject query = new BasicDBObject(); query = new BasicDBObject(); query.put("i", new BasicDBObject("$gt", 20).append("$lte", 30)); // i.e. 20 < i <= 30 <pre name="code" class="java"> DBCursor cur = coll.find(query); while(cur.hasNext()) { System.out.println(cur.next()); }注:查詢指定條件的offer信息。
DBObject tmpdoc = col.findOne(doc);注:查詢單條記錄;在很明確一條記錄有且只有一條時,findOne()比較方便,免得游標移動麻煩。
5.更新:
DBObject tmpdoc = col.findOne(doc); tmpdoc.put("i", (Integer)tmpdoc.get("i")+1); System.out.println("update obj: " + col.findOne(tmpdoc));注:更新一條記錄,先整個讀出再更新部分信息再寫入, 切記不要讀出一部分更新回去。
6.插入:
int i=1000; BasicDBObject doc = new BasicDBObject(); doc.put("i", i+1); col.insert(doc); System.out.println("insert obj: " + col.findOne(doc));注:插入一條記錄{i:1001},_id自動生成。
7.刪除:
BasicDBObject doc = new BasicDBObject(); doc.put("i", i+1); col.remove(doc); System.out.println("insert obj: " + col.findOne(doc));注:刪除一條記錄。
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!