Поля запроса в коллекции MongoDB. - PullRequest
7 голосов
/ 09 марта 2012

Я пытаюсь запросить определенные поля в коллекции mongodb.Вот мой код и вывод:

    Mongo m = new Mongo();
    DB db = m.getDB( "mydb" );
    DBCollection coll = db.getCollection("student") ;


    // adding data 
    BasicDBObject moz = new BasicDBObject();
    moz.put("Name", "Mozammil");
    coll.insert(moz);



    DBCursor cursor = coll.find();


    while (cursor.hasNext()) {
        System.out.println(cursor.next());

    }

Это возвращает следующее:

{ "_id" : { "$oid" : "4f5a4477c5e80f71ece56797"} , "Name" : "Mozammil"}

Однако я хочу только часть имени.Погуглив вокруг, это должно сделать работу.

    DBCursor cursor = coll.find({}, {'Name':1});


    while (cursor.hasNext()) {
        System.out.println(cursor.next());
    }

Но это не работает.Помогите, пожалуйста?

Ответы [ 6 ]

9 голосов
/ 10 марта 2012

Я знаю, что вы уже приняли ответ, но это не совсем то, о чем вы просили.

Вот некоторый рабочий код:

// get Mongo set up...
Mongo m = new Mongo();
DB db = m.getDB( "test" );
DBCollection coll = db.getCollection("test");

// insert a test record
coll.insert(new BasicDBObject("Name","Wes").append("x", "to have a second field"));

// create an empty query
BasicDBObject query = new BasicDBObject(); 
// configure fields to be returned (true/1 or false/0 will work)
// YOU MUST EXPLICITLY CONFIGURE _id TO NOT SHOW
BasicDBObject fields = new BasicDBObject("Name",true).append("_id",false);

// do a query without specifying fields (and print results)
DBCursor curs = coll.find(query);
while(curs.hasNext()) {
   DBObject o = curs.next();
   System.out.println(o.toString());
}

// do a query specifying the fields (and print results)
curs = coll.find(query, fields);
while(curs.hasNext()) {
   DBObject o = curs.next();
   System.out.println(o.toString());
}

Первый вывод результатов:

{ "_id" : { "$oid" : "4f5a6c1603647d34f921f967"} , "Name" : "Wes" , "x" : "to have a second field"}

И второй запрос выводит:

{ "Name" : "Wes"}
9 голосов
/ 09 марта 2012

Вы можете использовать get на возвращенном документе курсором, чтобы получить искомое поле.Как это:

System.out.println(cursor.next().get("key"));
6 голосов
/ 09 марта 2012

Взгляните на DBCollection.find

BasicDBObject query = new BasicDBObject(); // because you have no conditions
BasicDBObject fields = new BasicDBObject("Name",1);
coll.find(query, fields);
1 голос
/ 22 июня 2016
collection.find().projection(Projections.include("Name"))

это сработало очень хорошо !!!

0 голосов
/ 11 января 2019

Чтобы получить все вложенные ключи:

    public static ArrayList<String> getKeys(Document it1) throws JSONException {

        ArrayList<String> result = new ArrayList<String>();
        ArrayList<String> resultTemp;
        String temp;
        Document doc;
        JSONArray jsa;

        int len, i;
        System.out.println(it1);
        String js = it1.toJson();
        JSONObject js1 = new JSONObject(js);

        Iterator<String> keys = js1.keys();
        while (keys.hasNext()) {
            String key = keys.next();
            if (key.equals("_id")) {
                result.add(key);
                continue;
            }
            System.out.println(key);

            temp = js1.get(key).toString();
            if (temp.contains(":")) {
                jsa = new JSONArray(temp);
                len = jsa.length();
                for (i = 0; i < len; i++) {
                    JSONObject object = jsa.getJSONObject(i);
                    doc = Document.parse(object.toString());
                    System.out.println(doc);
                    resultTemp = getKeys(doc);
                    for (String keyTemp : resultTemp) {
                        if (!result.contains(key + "." + keyTemp))
                            result.add(key + "." + keyTemp);
                    }
                }
            } else {
                result.add(key);
            }

        }
        return result;
    }
0 голосов
/ 03 марта 2016
BasicDBObject query = new BasicDBObject();

BasicDBObject fields = new BasicDBObject();
fields.put("name", 1);

DBCursor cursor = collection.find(query, fields);
while (cursor.hasNext()) {
    System.out.println(cursor.next());
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...