Java MongoDB : Query document

In this tutorial, we show you few common ways to get or query document from collection.

Test Data

Insert 5 dummy documents for testing.


{ "_id" : { "$oid" : "id"} , "number" : 1 , "name" : "mkyong-1"}
{ "_id" : { "$oid" : "id"} , "number" : 2 , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "id"} , "number" : 3 , "name" : "mkyong-3"}
{ "_id" : { "$oid" : "id"} , "number" : 4 , "name" : "mkyong-4"}
{ "_id" : { "$oid" : "id"} , "number" : 5 , "name" : "mkyong-5"}

1. Find() examples

1.1 Get first matched document only.


    DBObject doc = collection.findOne();
    System.out.println(dbObject);

Output


    { "_id" : { "$oid" : "id"} , "number" : 1 , "name" : "mkyong-1"}

1.2 Get all matched documents.


    DBCursor cursor = collection.find();
    while(cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "_id" : { "$oid" : "id"} , "number" : 1 , "name" : "mkyong-1"}
{ "_id" : { "$oid" : "id"} , "number" : 2 , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "id"} , "number" : 3 , "name" : "mkyong-3"}
{ "_id" : { "$oid" : "id"} , "number" : 4 , "name" : "mkyong-4"}
{ "_id" : { "$oid" : "id"} , "number" : 5 , "name" : "mkyong-5"}

1.3 Get single field from matched document.


    BasicDBObject allQuery = new BasicDBObject();
    BasicDBObject fields = new BasicDBObject();
    fields.put("name", 1);
    
    DBCursor cursor = collection.find(allQuery, fields);
    while (cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "_id" : { "$oid" : "id"} , "name" : "mkyong-1"}
{ "_id" : { "$oid" : "id"} , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "id"} , "name" : "mkyong-3"}
{ "_id" : { "$oid" : "id"} , "name" : "mkyong-4"}
{ "_id" : { "$oid" : "id"} , "name" : "mkyong-5"}

2. Find() and Comparison

2.1 Get all documents where number = 5.


    BasicDBObject whereQuery = new BasicDBObject();
    whereQuery.put("number", 5);
    DBCursor cursor = collection.find(whereQuery);
    while(cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "_id" : { "$oid" : "id"} , "number" : 5 , "name" : "mkyong-5"}

2.2 $in example – Get documents where number in 2, 4 and 5.


    BasicDBObject inQuery = new BasicDBObject();
    List<Integer> list = new ArrayList<Integer>();
    list.add(2);
    list.add(4);
    list.add(5);
    inQuery.put("number", new BasicDBObject("$in", list));
    DBCursor cursor = collection.find(inQuery);
    while(cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com


{ "_id" : { "$oid" : "id"} , "number" : 2 , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "id"} , "number" : 4 , "name" : "mkyong-4"}
{ "_id" : { "$oid" : "id"} , "number" : 5 , "name" : "mkyong-5"}

2.3 $gt $lt example – Get documents where 5 > number > 2 .


    BasicDBObject gtQuery = new BasicDBObject();
    gtQuery.put("number", new BasicDBObject("$gt", 2).append("$lt", 5));
    DBCursor cursor = collection.find(gtQuery);
    while(cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "_id" : { "$oid" : "id"} , "number" : 3 , "name" : "mkyong-3"}
{ "_id" : { "$oid" : "id"} , "number" : 4 , "name" : "mkyong-4"}

2.4 $ne example – Get documents where number != 4 .


    BasicDBObject neQuery = new BasicDBObject();
    neQuery.put("number", new BasicDBObject("$ne", 4));
    DBCursor cursor = collection.find(neQuery);
    while(cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "_id" : { "$oid" : "id"} , "number" : 1 , "name" : "mkyong-1"}
{ "_id" : { "$oid" : "id"} , "number" : 2 , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "id"} , "number" : 3 , "name" : "mkyong-3"}
{ "_id" : { "$oid" : "id"} , "number" : 5 , "name" : "mkyong-5"}

3. find() and Logical

3.1 $and example – get documents where number = 2 and name = 'mkyong-2'.


    BasicDBObject andQuery = new BasicDBObject();
    List<BasicDBObject> obj = new ArrayList<BasicDBObject>();
    obj.add(new BasicDBObject("number", 2));
    obj.add(new BasicDBObject("name", "mkyong-2"));
    andQuery.put("$and", obj);

    System.out.println(andQuery.toString());

    DBCursor cursor = collection.find(andQuery);
    while (cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "$and" : [ { "number" : 2} , { "name" : "mkyong-2"}]}

{ "_id" : { "$oid" : "id"} , "number" : 2 , "name" : "mkyong-2"}

4. find() and Regex

Find document with regular expression pattern.

4.1 $regex example – get documents where name like pattern 'Mky.*-[1-3]', case insensitive.


    BasicDBObject regexQuery = new BasicDBObject();
    regexQuery.put("name", 
        new BasicDBObject("$regex", "Mky.*-[1-3]")
        .append("$options", "i"));
            
    System.out.println(regexQuery.toString());
            
    DBCursor cursor = collection.find(regexQuery);
    while (cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Output


{ "name" : { "$regex" : "Mky.*-[1-3]" , "$options" : "i"}}

{ "_id" : { "$oid" : "515ad59e3004c89329c7b259"} , "number" : 1 , "name" : "mkyong-1"}
{ "_id" : { "$oid" : "515ad59e3004c89329c7b25a"} , "number" : 2 , "name" : "mkyong-2"}
{ "_id" : { "$oid" : "515ad59e3004c89329c7b25b"} , "number" : 3 , "name" : "mkyong-3"}
There are more…
Read this MongoDB operator documentation for complete set of query operators supported in MongoDB.

5. Full Example


package com.mkyong.core;

import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.Calendar;
import java.util.List;

import com.mongodb.BasicDBObject;
import com.mongodb.DB;
import com.mongodb.DBCollection;
import com.mongodb.DBCursor;
import com.mongodb.DBObject;
import com.mongodb.Mongo;
import com.mongodb.MongoException;

/**
 * Java MongoDB : Query document
 * 
 * @author mkyong
 * 
 */
public class QueryApp {

    public static void insertDummyDocuments(DBCollection collection) {

        List<DBObject> list = new ArrayList<DBObject>();

        Calendar cal = Calendar.getInstance();

        for (int i = 1; i <= 5; i++) {

            BasicDBObject data = new BasicDBObject();
            data.append("number", i);
            data.append("name", "mkyong-" + i);
            // data.append("date", cal.getTime());

            // +1 day
            cal.add(Calendar.DATE, 1);

            list.add(data);

        }

        collection.insert(list);

    }

    public static void main(String[] args) {

    try {

      Mongo mongo = new Mongo("localhost", 27017);
      DB db = mongo.getDB("yourdb");

      // get a single collection
      DBCollection collection = db.getCollection("dummyColl");

      insertDummyDocuments(collection);

      System.out.println("1. Find first matched document");
      DBObject dbObject = collection.findOne();
      System.out.println(dbObject);

      System.out.println("\n1. Find all matched documents");
      DBCursor cursor = collection.find();
      while (cursor.hasNext()) {
        System.out.println(cursor.next());
      }

      System.out.println("\n1. Get 'name' field only");
      BasicDBObject allQuery = new BasicDBObject();
      BasicDBObject fields = new BasicDBObject();
      fields.put("name", 1);

      DBCursor cursor2 = collection.find(allQuery, fields);
      while (cursor2.hasNext()) {
        System.out.println(cursor2.next());
      }

      System.out.println("\n2. Find where number = 5");
      BasicDBObject whereQuery = new BasicDBObject();
      whereQuery.put("number", 5);
      DBCursor cursor3 = collection.find(whereQuery);
      while (cursor3.hasNext()) {
        System.out.println(cursor3.next());
      }

      System.out.println("\n2. Find where number in 2,4 and 5");
      BasicDBObject inQuery = new BasicDBObject();
      List<Integer> list = new ArrayList<Integer>();
      list.add(2);
      list.add(4);
      list.add(5);
      inQuery.put("number", new BasicDBObject("$in", list));
      DBCursor cursor4 = collection.find(inQuery);
      while (cursor4.hasNext()) {
        System.out.println(cursor4.next());
      }

      System.out.println("\n2. Find where 5 > number > 2");
      BasicDBObject gtQuery = new BasicDBObject();
      gtQuery.put("number", new BasicDBObject("$gt", 2).append("$lt", 5));
      DBCursor cursor5 = collection.find(gtQuery);
      while (cursor5.hasNext()) {
        System.out.println(cursor5.next());
      }

      System.out.println("\n2. Find where number != 4");
      BasicDBObject neQuery = new BasicDBObject();
      neQuery.put("number", new BasicDBObject("$ne", 4));
      DBCursor cursor6 = collection.find(neQuery);
      while (cursor6.hasNext()) {
        System.out.println(cursor6.next());
      }

      System.out.println("\n3. Find when number = 2 and name = 'mkyong-2' example");
      BasicDBObject andQuery = new BasicDBObject();

      List<BasicDBObject> obj = new ArrayList<BasicDBObject>();
      obj.add(new BasicDBObject("number", 2));
      obj.add(new BasicDBObject("name", "mkyong-2"));
      andQuery.put("$and", obj);

      System.out.println(andQuery.toString());

      DBCursor cursor7 = collection.find(andQuery);
      while (cursor7.hasNext()) {
        System.out.println(cursor7.next());
      }

      System.out.println("\n4. Find where name = 'Mky.*-[1-3]', case sensitive example");
      BasicDBObject regexQuery = new BasicDBObject();
      regexQuery.put("name",
        new BasicDBObject("$regex", "Mky.*-[1-3]")
                    .append("$options", "i"));

      System.out.println(regexQuery.toString());

      DBCursor cursor8 = collection.find(regexQuery);
      while (cursor8.hasNext()) {
        System.out.println(cursor8.next());
      }

      collection.drop();

      System.out.println("Done");

     } catch (UnknownHostException e) {
        e.printStackTrace();
     } catch (MongoException e) {
        e.printStackTrace();
     }

    }
}

Done.

 

[출처] https://mkyong.com/mongodb/java-mongodb-query-document/

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
404 자바 인코딩 관련 문제 종합 정리 file 졸리운_곰 2021.01.29 40
403 JAVA) 예외처리(throw , throws) file 졸리운_곰 2021.01.24 21
402 [Java 디자인패턴] [JAVA 디자인 패턴] static을 응용한 싱글톤 패턴(Singleton Pattern) 구현 졸리운_곰 2021.01.22 20
401 예외처리 (throwable, exception, error, throws) file 졸리운_곰 2021.01.21 39
400 Eclipse -`항상 실행 백그라운드에서 실행 '창을 다시 표시하는 방법 file 졸리운_곰 2021.01.14 439
399 Prometheus + Grafana로 Java 애플리케이션 모니터링하기 file 졸리운_곰 2020.12.17 79
398 [스프링 배치] java Spring Batch 졸리운_곰 2020.12.16 77
397 [java] [MyBatis] #{} 와 ${} 개념과 차이점 졸리운_곰 2020.12.11 47
396 [java, mybatis] MyBatis에서 샾(#{})과 달러(${})의 차이는 무엇일까? 졸리운_곰 2020.12.11 66
395 [Java] 자바 extends, implements 차이 file 졸리운_곰 2020.12.10 48
394 [JAVA] String to int, int to String 형변환 컴퓨터/코딩 졸리운_곰 2020.12.10 35
393 [Java] 현재날짜 구하기 졸리운_곰 2020.12.10 15
392 [Java] [Java] Jackson으로 Json <-> Object 변환(Transformation)하기 졸리운_곰 2020.12.09 18
391 [java] jackson custom serializer, deserializer 만들기 file 졸리운_곰 2020.12.09 60
390 [Java] Deserialize MongoDB date fields to Java POJO Using Jackson 졸리운_곰 2020.12.09 132
389 [Java] Jackson ObjectMapper upper/lower case issues 졸리운_곰 2020.12.09 473
388 Java의 날짜와 시간 API file 졸리운_곰 2020.12.03 41
387 Java로 현재 날짜 / 시간을 얻는 방법 file 졸리운_곰 2020.11.30 451
386 [java, jackson] [jackson] json serialize 만 ignore 하고 싶다면? 졸리운_곰 2020.11.07 16
» Java MongoDB : Query document 졸리운_곰 2020.11.07 30
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED