java中mongodb的查詢及排序

轉自:

http://www.zicheng.net/article/982042.htm


 Mongodb除了高性能外,還有完善的API進行各種查詢操作,本教程中,我將爲你演示一些通用的方法來實現mongodb的查詢,包括組合查詢,區間查詢,like查詢,in查詢等方法。希望在閱讀本文後能舉一反三組合成更復雜的查詢。

 

下面直接上代碼,每個代碼裏有詳細的註釋,有疑問請留言。


001 public class MongoDbFind {
002     public static final int port = 27017;
003     public static final String host = "127.0.0.1";
004     /**
005      * 獲取數據庫對象
006      *
007      * @return
008      */
009     private MongoDatabase getDb() {
010         MongoClient mongo = new MongoClient(host, port);
011         MongoDatabase db = mongo.getDatabase("new_db");
012         return db;
013     }
014     /**
015      * 獲取表(集合)
016      *
017      * @return
018      */
019     private MongoCollection getCollection() {
020         MongoDatabase db = getDb();
021         MongoCollection<Document> table = db.getCollection("user");
022         return table;
023     }
024     /**
025      * 查詢出一條數據
026      */
027     @Test
028     public void findOne() {
029         MongoCollection table = getCollection();
030         BasicDBObject dbObject = new BasicDBObject();
031         //mongodb中按age字段倒序查詢(-1是倒序,1是正序)
032         dbObject.put("age",-1);
033         FindIterable iterate = table.find().sort(dbObject).limit(1);
034         System.out.println(iterate.iterator().tryNext());
035     }
036     /**
037      * mongodb分頁查詢
038      *
039      * @param pageIndex 當前頁碼
040      */
041     private void findPage(int pageIndex) {
042         int pageSize = 3;
043         MongoCollection table = getCollection();
044         //mongodb分頁查詢出遊標
045         MongoCursor cursor = table.find().limit(pageSize).skip((pageIndex - 1) * pageSize).iterator();
046         System.out.println("當前頁:" + pageIndex);
047         while (cursor.hasNext()) {
048             System.out.println(cursor.next());
049         }
050     }
051     @Test
052     public void findPage() {
053         findPage(1);
054         findPage(2);
055     }
056     /**
057      * 等於查詢
058      */
059     @Test
060     public void comparison() {
061         MongoCollection table = getCollection();
062         BasicDBObject dbObject = new BasicDBObject();
063         dbObject.put("age"20);
064         //查詢出年齡是20的記錄
065         MongoCursor cursor = table.find(dbObject).iterator();
066         while (cursor.hasNext()) {
067             System.out.println(cursor.next());
068         }
069     }
070     /**
071      * 使用in包含查詢
072      */
073     @Test
074     public void findIn() {
075         //定義一個數組存儲in查詢的條件值
076         List<Integer> list = new ArrayList<>(4);
077         list.add(20);
078         list.add(28);
079         list.add(15);
080         list.add(13);
081         MongoCollection table = getCollection();
082         BasicDBObject dbObject = new BasicDBObject();
083         //這裏使用BasicDBObject嵌套來並使用$in預定義名稱來實現mongodb的in查詢功能
084         dbObject.put("age"new BasicDBObject("$in", list));
085         MongoCursor cursor = table.find(dbObject).iterator();
086         while (cursor.hasNext()) {
087             System.out.println(cursor.next());
088         }
089     }
090     /**
091      * 大於小於區間查詢
092      */
093     @Test
094     public void findGtLt()
095     {
096         MongoCollection table = getCollection();
097         BasicDBObject dbObject = new BasicDBObject();
098         //mongodb實現大於小於區間的查詢,注意大於是$gt,小於是$lt
099         dbObject.put("age"new BasicDBObject("$gt"15).append("$lt",25));
100         MongoCursor cursor = table.find(dbObject).iterator();
101         while (cursor.hasNext()) {
102             System.out.println(cursor.next());
103         }
104     }
105     /**
106      * 不等於查詢
107      */
108     @Test
109     public void findNe()
110     {
111         MongoCollection table = getCollection();
112         BasicDBObject dbObject = new BasicDBObject();
113         dbObject.put("age"new BasicDBObject("$ne",17));
114         MongoCursor cursor = table.find(dbObject).iterator();
115         while (cursor.hasNext()) {
116             System.out.println(cursor.next());
117         }
118     }
119     /**
120      * 多條件查詢
121      */
122     @Test
123     public void findMulti()
124     {
125         MongoCollection table = getCollection();
126         //多條件查詢需要先定義一個BasicDBObject數組來存儲多個條件
127         List<BasicDBObject> objects = new ArrayList<BasicDBObject>();
128         objects.add(new BasicDBObject("age"new BasicDBObject("$ne"17)));
129         objects.add(new BasicDBObject("name","zicheng-3"));
130         BasicDBObject query=new BasicDBObject();
131         query.put("$and",objects);
132         MongoCursor cursor = table.find(query).iterator();
133         while (cursor.hasNext()) {
134             System.out.println(cursor.next());
135         }
136     }
137     /**
138      * 通過使用正則表達式模糊查詢
139      */
140     @Test
141     public void findRegex()
142     {
143         MongoCollection table = getCollection();
144         BasicDBObject regexQuery = new BasicDBObject();
145         regexQuery.put("name"new BasicDBObject("$regex""自成.*-[1-8]"));
146         //打印mongodb的查詢條件
147        // System.out.println(regexQuery.toString());
148         MongoCursor cursor = table.find(regexQuery).iterator();
149         while (cursor.hasNext()) {
150             System.out.println(cursor.next());
151         }
152     }
153 }

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章