Java實現對MongoDB的AND、OR和IN操做 ,大於、小於等判斷

本文轉自http://blog.csdn.net/mydeman/article/details/6652387java

在MongoDB的官方文檔中關於Java操做的介紹,只給出了很簡單的幾個例子。這些例子雖然能夠知足必定的需求,可是還並非太徹底。下面是我根據網頁中的提示寫的幾個例子。mongodb

1.背景。用JUnit4.8.2實現的單元測試的形式。測試數據:數據庫

[plain] view plaincopyprint?單元測試

  1. {uid:10,username:"Jim",age:23,agender:"male"}測試

  2. {uid:27,username:"tom",age:13,agender:"male"}ui

  3. {uid:12,username:"Jane",age:31,agender:"female"}spa

  4. {uid:23,username:"Alex",age:47,agender:"male"}.net

  5. {uid:109,username:"Lily",age:24,agender:"female"}code

{uid:10,username:"Jim",age:23,agender:"male"}
{uid:27,username:"tom",age:13,agender:"male"}
{uid:12,username:"Jane",age:31,agender:"female"}
{uid:23,username:"Alex",age:47,agender:"male"}
{uid:109,username:"Lily",age:24,agender:"female"}


單元測試的初始化和清理工做,主要是創建數據庫鏈接、寫入測試數據、清理測試數據:blog

[java] view plaincopyprint?

  1. private static List<BasicDBObject> documents = new ArrayList<BasicDBObject>();

  2. private static DBCollection coll;

  3. @BeforeClass

  4. public static void init(){

  5. try {

  6. initConnection();

  7. loadData();

  8. } catch (Exception e) {

  9. e.printStackTrace();

  10. }

  11. }

  12. private static void initConnection() throws UnknownHostException, MongoException{

  13. //Create a connection to Collection 'user'

  14. Mongo mongo = new Mongo("localhost", 27017);

  15. DB db = mongo.getDB("test");

  16. coll = db.getCollection("user");

  17. }

  18. private static void loadData() throws Exception{

  19. BufferedReader br = new BufferedReader(new InputStreamReader(MongoTest.class.getResourceAsStream("data")));

  20. String line = null;

  21. while((line = br.readLine()) != null){

  22. JSONObject jo = new JSONObject(line);

  23. //Convert JSONObject into BasicDBObject

  24. BasicDBObject dbObject = new BasicDBObject();

  25. Iterator<String> joKeys = jo.keys();

  26. while(joKeys.hasNext()){

  27. String key = joKeys.next();

  28. dbObject.put(key, jo.get(key));

  29. }

  30. documents.add(dbObject);

  31. }

  32. }

  33. @Before

  34. public void setUp(){

  35. //Insert all data into MongoDB

  36. for(BasicDBObject bdo : documents){

  37. coll.insert(bdo);

  38. }

  39. }

  40. @After

  41. public void cleanUp(){

  42. //Drop the collection to remove all data.

  43. //Note: it's not recommended.

  44. coll.drop();

  45. }

  private static List<BasicDBObject> documents = new ArrayList<BasicDBObject>();
        private static DBCollection coll;
        
        @BeforeClass
        public static void init(){
                try {
                        
                        initConnection();
                        
                        loadData();
                } catch (Exception e) {
                        e.printStackTrace();
                }
        }
        
        private static void initConnection() throws UnknownHostException, MongoException{
                //Create a connection to Collection 'user'
                Mongo mongo = new Mongo("localhost", 27017);
                DB db = mongo.getDB("test");
                coll = db.getCollection("user");
        }
        
        private static void loadData() throws Exception{
                BufferedReader br = new BufferedReader(new InputStreamReader(MongoTest.class.getResourceAsStream("data")));
                String line = null;
                while((line = br.readLine()) != null){
                        JSONObject jo = new JSONObject(line);
                        
                        //Convert JSONObject into BasicDBObject
                        BasicDBObject dbObject = new BasicDBObject();
                        Iterator<String> joKeys = jo.keys();
                        while(joKeys.hasNext()){
                                String key = joKeys.next();
                                dbObject.put(key, jo.get(key));
                        }
                        
                        documents.add(dbObject);
                }
        }
        
        @Before
        public void setUp(){
                //Insert all data into MongoDB
                for(BasicDBObject bdo : documents){
                        coll.insert(bdo);
                }
        }
        
        @After
        public void cleanUp(){
                //Drop the collection to remove all data.
                //Note: it's not recommended.
                coll.drop();
        }


2. AND是比較簡單的。

[java] view plaincopyprint?

  1. @Test

  2. public void testAnd(){

  3. //agender='female' AND age > 27

  4. DBObject queryCondition = new BasicDBObject();

  5. queryCondition.put("agender", "female");

  6. queryCondition.put("age", new BasicDBObject("$gt", 27));

  7. DBCursor dbCursor = coll.find(queryCondition);

  8. assertEquals(1, dbCursor.size());

  9. assertEquals("Jane", dbCursor.next().get("username"));

  10. }

  @Test
        public void testAnd(){
                //agender='female' AND age > 27      
                DBObject queryCondition = new BasicDBObject();
                queryCondition.put("agender", "female");
                queryCondition.put("age", new BasicDBObject("$gt", 27));
                DBCursor dbCursor = coll.find(queryCondition);
                assertEquals(1, dbCursor.size());
                assertEquals("Jane", dbCursor.next().get("username"));
        }


3.單個字段的OR操做。

[java] view plaincopyprint?

  1. @Test

  2. public void testOrSingleField(){

  3. DBObject queryCondition = new BasicDBObject();

  4. //age<15 OR age>27

  5. queryCondition = new BasicDBObject();

  6. BasicDBList values = new BasicDBList();

  7. values.add(new BasicDBObject("age", new BasicDBObject("$gt", 27)));

  8. values.add(new BasicDBObject("age", new BasicDBObject("$lt", 15)));

  9. queryCondition.put("$or", values);

  10. DBCursor dbCursor = coll.find(queryCondition);

  11. assertEquals(3, dbCursor.size());

  12. assertEquals("tom", dbCursor.next().get("username"));

  13. }

  @Test
        public void testOrSingleField(){
                DBObject queryCondition = new BasicDBObject();          
                //age<15 OR age>27
                queryCondition = new BasicDBObject();
                BasicDBList values = new BasicDBList();
                values.add(new BasicDBObject("age", new BasicDBObject("$gt", 27)));
                values.add(new BasicDBObject("age", new BasicDBObject("$lt", 15)));
                queryCondition.put("$or", values);
                
                DBCursor dbCursor = coll.find(queryCondition);
                assertEquals(3, dbCursor.size());
                assertEquals("tom", dbCursor.next().get("username"));
        }


4. 多個字段之間的OR操做

[java] view plaincopyprint?

  1. @Test

  2. public void testOrMultiFields(){

  3. DBObject queryCondition = new BasicDBObject();

  4. //agender=female OR age<=23

  5. queryCondition = new BasicDBObject();

  6. BasicDBList values = new BasicDBList();

  7. values.add(new BasicDBObject("agender", "female"));

  8. values.add(new BasicDBObject("age", new BasicDBObject("$lte", 23)));

  9. queryCondition.put("$or", values);

  10. DBCursor dbCursor = coll.find(queryCondition);

  11. assertEquals(4, dbCursor.size());

  12. assertEquals("Jim", dbCursor.next().get("username"));

  13. }

  @Test
        public void testOrMultiFields(){
                DBObject queryCondition = new BasicDBObject();          
                //agender=female OR age<=23
                queryCondition = new BasicDBObject();
                BasicDBList values = new BasicDBList();
                values.add(new BasicDBObject("agender", "female"));
                values.add(new BasicDBObject("age", new BasicDBObject("$lte", 23)));
                queryCondition.put("$or", values);
                
                DBCursor dbCursor = coll.find(queryCondition);
                assertEquals(4, dbCursor.size());
                assertEquals("Jim", dbCursor.next().get("username"));
        }


5. 單個字段的IN操做。對於相似 where age=13 OR age=47的查詢條件,就能夠考慮使用IN代替

[java] view plaincopyprint?

  1. @Test

  2. public void testIn(){

  3. DBObject queryCondition = new BasicDBObject();

  4. //age in [13, 47]

  5. queryCondition = new BasicDBObject();

  6. BasicDBList values = new BasicDBList();

  7. values.add(13);

  8. values.add(47);

  9. queryCondition.put("age", new BasicDBObject("$in", values));

  10. DBCursor dbCursor = coll.find(queryCondition);

  11. assertEquals(2, dbCursor.size());

  12. assertEquals("tom", dbCursor.next().get("username"));

  13. }

  @Test
        public void testIn(){
                DBObject queryCondition = new BasicDBObject();          
                //age in [13, 47]
                queryCondition = new BasicDBObject();
                BasicDBList values = new BasicDBList();
                values.add(13);
                values.add(47);
                queryCondition.put("age", new BasicDBObject("$in", values));
                
                DBCursor dbCursor = coll.find(queryCondition);
                assertEquals(2, dbCursor.size());
                assertEquals("tom", dbCursor.next().get("username"));
        }

從以上幾個例子能夠看出,經過BasicDBList與BasicDBObject的相結合能夠得出比較複雜的查詢條件。

相關文章
相關標籤/搜索