通過 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 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!