Как запросить документы, используя поле "_id" в драйвере Java mongodb? - PullRequest
32 голосов
/ 21 марта 2012

Я пытаюсь найти документы в MongoDB, выполнив поиск по ключу "_id". Мой документ выглядит так -

{
  "_id" : ObjectId("4f693d40e4b04cde19f17205"),
  "hostname" : "hostnameGoesHere",
  "OSType" : "OSTypeGoesHere"
}

Я пытаюсь найти этот документ как -

ObjectId id= new ObjectId("4f693d40e4b04cde19f17205");        
BasicDBObject obj = new BasicDBObject();        
obj.append("_id", id);        
BasicDBObject query = new BasicDBObject();        
query.putAll(query);

Но я получаю ошибку ниже -

error: reference to putAll is ambiguous, both method putAll(Map) in BasicBSONObject and method putAll(BSONObject) in BasicBSONObject match
        query.putAll(query);

Метод добавления BasicDBObject поддерживает (String Key, Value), и если я передам «_id» в качестве String этому методу, никакие документы не будут сопоставлены.

Итак, мой вопрос: как мне передать "_id"?

Ответы [ 4 ]

57 голосов
/ 09 октября 2012

Не уверен, что другие могут искать ответы на эту тему, но вот самый простой способ поиска записи MongoDB, основанной на "_id".Документация MongoDB не обновляется и по-прежнему показывает ObjectId как часть пакета com.mongodb (он также обычно не дает много информации о поиске по ObjectId).

import org.bson.types.ObjectId;

public DBObject findDocumentById(String id) {

    BasicDBObject query = new BasicDBObject();
    query.put("_id", new ObjectId(id));

    DBObject dbObj = collection.findOne(query);
    return dbObj;
}
16 голосов
/ 09 ноября 2017

Для тех, кто ищет более современный метод, особенно с 3.4:

import com.mongodb.client.MongoCollection;
import com.mongodb.client.MongoDatabase;
import org.bson.Document;
import org.bson.types.ObjectId;

import static com.mongodb.client.model.Filters.eq;

//......
MongoCollection<Document> myCollection = database.getCollection("myCollection");
Document document = myCollection.find(eq("_id", new ObjectId("4f693d40e4b04cde19f17205"))).first();
if (document == null) {
    //Document does not exist
} else {
    //We found the document
}
2 голосов
/ 12 июля 2016

Вы можете сделать это

 ObjectId id= new ObjectId("4f693d40e4b04cde19f17205");        
    BasicDBObject obj = new BasicDBObject();        
    obj.append("_id", id);        
    BasicDBObject query = new BasicDBObject();        
    query.putAll((BSONObject)query);
2 голосов
/ 21 марта 2012

Решено с помощью запроса as-

query.putAll((BSONObject)query);
...