導航:首頁 > 編程語言 > javamongodb數組

javamongodb數組

發布時間:2025-02-20 05:30:14

⑴ mongo-java-driver,java怎麼查詢MongoDB,並做時間分組統計

java操作mongodb進行查詢,常用篩選條件的設置如下:

條件列表:

BasicDBListcondList=newBasicDBList();

臨時條件對象:

BasicDBObjectcond=null;

DBCollectioncoll=db.getCollection("A");

1、$where

在某種應用場合,若要集合A查詢文檔且要滿足文檔中某些屬性運算結果,可以編寫一腳本函數用where進行設置,比如:

某集合中存放的用戶信息,包括姓名、年齡、手機號、地址等,要篩選出年齡大於20且小於等於40的用戶,我們可以這樣:

StringageStr="function(){returnparseFloat(this.age)>20&&parseFloat(this.age)<=40};"洞廳;

cond=納信隱newBasicDBObject();

cond.put("$where",ageStr);

放入條件列表

condList.add(cond);

2、$in

接1實例中,要查詢年齡為23、40、50的用戶信息,我們可以這樣:

創建一個臨時的條件列表對象,將條件值分別添加進去

BasicDBListvalues=newBasicDBList();

values.add(23);

values.add(40);

values.add(50);

cond=newBasicDBObject();

cond.put("age",newBasicDBObject("$in",values));

放入條件列表

condList.add(cond);

3、模糊匹配

接1實例中,要按照用戶的姓名進行模糊查詢,如:王,我們可以這樣做:

使用不區分大小寫的模糊查詢

3.1完全匹配

Patternpattern=Pattern.compile("^王$",Pattern.CASE_INSENSITIVE);

3.2右匹配

Patternpattern=Pattern.compile("^.*王$",Pattern.CASE_INSENSITIVE);

3.3左匹配

Patternpattern=Pattern.compile("^王.*$",Pattern.CASE_INSENSITIVE);

3.4模糊匹配

Patternpattern=Pattern.compile("^.*王.*$",Pattern.CASE_INSENSITIVE);

cond=newBasicDBObject();

cond.put("name",cond);

放入條件列表

condList.add(cond);

4、$gte/$lte/$gt/$lt

接1實例中,要篩選出年齡大於20且小於等於40的用戶,我們可以這樣:

cond=newBasicDBObject();

cond.append("age",newBasicDBObject("$gt",20));

cond.append("age",newBasicDBObject("$lte",40));

放入條件列表

condList.add(cond);

在日常的查詢中篩選的條件可能會有多個,而且多個條件之間都是且的關系,結合上例1、2、3、4中

將每種條件添加到條件列坦念表中,我可以這樣:

BasicDBObjectsearchCond=newBasicDBObject();

searchCond.put("$and",condList);

然後查詢數據:

DBCursorret=coll.find(searchCond);

閱讀全文

與javamongodb數組相關的資料

熱點內容
如何在php中加入視頻 瀏覽:87
知音唱歌app在哪裡 瀏覽:76
fraps視頻壓縮 瀏覽:302
資料庫查詢系統源碼 瀏覽:622
php5314 瀏覽:361
完美國際安裝到哪個文件夾 瀏覽:673
什麼app可以掃一掃做題 瀏覽:544
程序員編碼論壇 瀏覽:930
淘點是什麼app 瀏覽:662
中國高等植物pdf 瀏覽:456
51單片機時間 瀏覽:185
後台如何獲取伺服器ip 瀏覽:270
單片機流水燈程序c語言 瀏覽:237
程序員第二職業掙錢 瀏覽:242
運行里怎麼輸入伺服器路徑 瀏覽:844
pythonstepwise 瀏覽:514
劉一男詞彙速記指南pdf 瀏覽:69
php認證級別 瀏覽:372
方舟編譯啥時候推送 瀏覽:1014
php手機驗證碼生成 瀏覽:679