亚洲Aⅴ无码Av红楼在线观看_国产午夜福利涩爱AⅤ_国产sm调教一区二区三区_精品人妻一区二区三区不卡毛片

始創(chuàng)于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業(yè)
  • 60秒人工響應(yīng)
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
全部產(chǎn)品
您的位置: 網(wǎng)站首頁 > 幫助中心>文章內(nèi)容

MongoDB Java接入

發(fā)布時間:  2012/8/31 17:32:29

MongoDB的Java驅(qū)動已經(jīng)提供比較全的操作,分為三塊:

1.普通用戶操作

2.管理員操作

3.oplog操作

具體可以添加一個eclipse testng插件,再在工程中導(dǎo)入testng.jar包即可看到。

本文主要說明各個使用點和注意事項。

 


1.連接一個復(fù)制集(replica sets)mongod:
-
 

復(fù)制集是mongo解決穩(wěn)定性的一個方案,也是可以實現(xiàn)讀寫分離的一種實現(xiàn),這里介紹復(fù)制集的java連接方式。


[java]
1.    static Mongo m; 
2.     
3.    static {  4.        List<ServerAddress> addresslist = new ArrayList<ServerAddress>();  5.        try {  6.            addresslist.add(new ServerAddress("127.0.0.1:10240"));  7.            addresslist.add(new ServerAddress("127.0.0.1:11240"));  8.            addresslist.add(new ServerAddress("127.0.0.1:12240"));  9.        } catch (UnknownHostException e) {  10.            System.err.println("address check error.");  11.            System.exit(-1);  12.        } 
13.         
14.        MongoOptions options = new MongoOptions();  15.        options.autoConnectRetry = true;  16.        options.connectionsPerHost = 20;  17.        options.connectTimeout = 6000;  18.        options.maxAutoConnectRetryTime = 12000;  19.        options.maxWaitTime = 12000;  20.        options.socketKeepAlive = true;  21.        options.socketTimeout = 2000;  22.         
23.        try {  24.            m = new Mongo(addresslist, options);  25.        } catch (MongoException e) {  26.            System.err.println("mongo create error.");  27.            System.exit(-1);  28.        } 
29.    } 
注:一般例子采用的連接方式是直接連一個mongod服務(wù),但是作為單臺的生產(chǎn)環(huán)境顯然安全性不足,因此采用復(fù)制集方式,連接也區(qū)別于一般,是使用


[java]
1.public Mongo( List<ServerAddress> replicaSetSeeds , MongoOptions options ) throws MongoException 
方法。

MongoOptions根據(jù)自己的需求設(shè)置,參數(shù)說明已經(jīng)很多了,不細講。

注意mongo實例使用單例模式。

 


2.獲取db:


[java]
1.DB db = m.getDB("test"); 
注:取到名為test的db進行操作;若該db不存在,該操作會創(chuàng)建對應(yīng)的db。

 

 

3.獲取集合:


[java]
1.DBCollection col = db.getCollection("offer"); 

注:取名字為offer的集合;類似于db的表。

 


以上三個操作是建立連接,接下去才是db中常用的操作。

 


4.查詢:


[java]
1.DBCursor cursor = col.find(); 
2.while(cursor.hasNext()) {  3. System.out.println(cursor.next()); 
4.    i++; 
5.} 
注:全集合查詢,輸出每條記錄,正常情況不會作類似操作,記住兩個東西,find()和cursor

 

 

[java]
1.BasicDBObject query = new BasicDBObject(); 
2.query = new BasicDBObject();  3.query.put("i", new BasicDBObject("$gt", 20).append("$lte", 30));  // i.e.   20 < i <= 30   4.<pre name="code" class="java">        DBCursor cur = coll.find(query);  5.while(cur.hasNext()) {  6.    System.out.println(cur.next()); 
7.} 

注:查詢指定條件的offer信息。

 

 

[java]
1.DBObject tmpdoc = col.findOne(doc); 
注:查詢單條記錄;在很明確一條記錄有且只有一條時,findOne()比較方便,免得游標移動麻煩。

 

 

5.更新:


[java]
1.DBObject tmpdoc = col.findOne(doc); 
2.tmpdoc.put("i", (Integer)tmpdoc.get("i")+1);  3.System.out.println("update obj: " + col.findOne(tmpdoc));  注:更新一條記錄,先整個讀出再更新部分信息再寫入,切記不要讀出一部分更新回去。

 

 

6.插入:

 

[java]
1.int i=1000; 
2.BasicDBObject doc = new BasicDBObject();  3.doc.put("i", i+1);  4.col.insert(doc); 
5.System.out.println("insert obj: " + col.findOne(doc));  注:插入一條記錄{i:1001},_id自動生成。

 

 

7.刪除:


[java]
1.BasicDBObject doc = new BasicDBObject(); 
2.doc.put("i", i+1);  3.         
4.col.remove(doc); 
5.System.out.println("insert obj: " + col.findOne(doc));  注:刪除一條記錄。


本文出自:億恩科技【www.allwellnessguide.com】

服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經(jīng)營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經(jīng)營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經(jīng)營性ICP/ISP證:贛B2-20080012
  • 服務(wù)器/云主機 24小時售后服務(wù)電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務(wù)電話:0371-60135900
  • 專注服務(wù)器托管17年
    掃掃關(guān)注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權(quán)所有  地址:鄭州市高新區(qū)翠竹街1號總部企業(yè)基地億恩大廈  法律顧問:河南亞太人律師事務(wù)所郝建鋒、杜慧月律師   京公網(wǎng)安備41019702002023號
      0
     
     
     
     

    0371-60135900
    7*24小時客服服務(wù)熱線