Получить идентификатор последнего вставленного документа в mongoDB с драйвером Java - PullRequest
99 голосов
/ 27 июля 2010

Есть ли простой способ получить идентификатор (ObjectID) последнего вставленного документа экземпляра mongoDB с помощью драйвера Java?

Ответы [ 8 ]

185 голосов
/ 27 июля 2010

Я только что понял, что вы можете сделать это:

BasicDBObject doc = new BasicDBObject( "name", "Matt" );
collection.insert( doc );
ObjectId id = (ObjectId)doc.get( "_id" );
11 голосов
/ 12 июля 2012

Это безопасно сделать

doc.set("_id", new ObjectId())

если вы посмотрите на код драйвера

if ( ensureID && id == null ){
    id = ObjectId.get();
    jo.put( "_id" , id );       
}

public static ObjectId get(){
    return new ObjectId();
}
8 голосов
/ 27 марта 2016

Чтобы избежать приведения от Object к ObjectId, при com.mongodb.client.MongoCollection collection и org.bson.Document doc, вы можете сделать следующее:

collection.insert(doc);
ObjectId id = doc.getObjectId("_id");
7 голосов
/ 30 июля 2010

Я не знаю о драйвере Java, но для потомков можно запустить команду getLastError, чтобы получить _id записи, даже upsert (по состоянию на 1.5.4)

1 голос
/ 29 января 2012

После того, как документ вставлен в коллекцию MongoDB, успешная вставка должна обновить необходимые поля (а именно _id) Вы можете запросить вставленный объект для _id.

0 голосов
/ 07 мая 2019

Я думаю, что ответ на это "Нет".

То, что вы можете сделать, - это предоставить _id самостоятельно, либо вручную, либо внедрить механизм CollectibleCodec (это именно то, что делает BasicBDDocument).Однако все эти решения включают создание идентификатора клиентской стороны.

Сказав это, я не думаю, что есть какие-либо проблемы с генерацией _id клиентской стороны.

0 голосов
/ 25 октября 2016

В MongoTemplate.class есть метод

protected <T> void doInsert(String collectionName, T objectToSave, MongoWriter<T> writer) {

    assertUpdateableIdIfNotSet(objectToSave);

    initializeVersionProperty(objectToSave);

    maybeEmitEvent(new BeforeConvertEvent<T>(objectToSave, collectionName));

    DBObject dbDoc = toDbObject(objectToSave, writer);

    maybeEmitEvent(new BeforeSaveEvent<T>(objectToSave, dbDoc, collectionName));
    Object id = insertDBObject(collectionName, dbDoc, objectToSave.getClass());

    populateIdIfNecessary(objectToSave, id);
    maybeEmitEvent(new AfterSaveEvent<T>(objectToSave, dbDoc, collectionName));
}

и метод установит идентификатор для нас

protected void populateIdIfNecessary(Object savedObject, Object id) {

    if (id == null) {
        return;
    }

    if (savedObject instanceof BasicDBObject) {
        DBObject dbObject = (DBObject) savedObject;
        dbObject.put(ID_FIELD, id);
        return;
    }

    MongoPersistentProperty idProp = getIdPropertyFor(savedObject.getClass());

    if (idProp == null) {
        return;
    }

    ConversionService conversionService = mongoConverter.getConversionService();
    MongoPersistentEntity<?> entity = mappingContext.getPersistentEntity(savedObject.getClass());
    PersistentPropertyAccessor accessor = entity.getPropertyAccessor(savedObject);

    if (accessor.getProperty(idProp) != null) {
        return;
    }

    new ConvertingPropertyAccessor(accessor, conversionService).setProperty(idProp, id);
}

мы можем видеть, является ли объект подклассом BasicDBObject, он установит для нас идентификатор.

0 голосов
/ 02 апреля 2013

Это операция вставки:

DBCollection table1 = db.getCollection("Collection name");
BasicDBObject document = new BasicDBObject();
document.put("_id",value);      
document.put("Name", name);
table1.insert(document);

После вставки вы получаете последний вставленный идентификатор:

DBCollection tableDetails = db.getCollection("collection name");
BasicDBObject queryDetails = new BasicDBObject();
queryDetails.put("_id", value);
DBCursor cursorDetails =tableDetails.find(queryDetails);
DBObject oneDetails;
oneDetails=cursorDetails.next();        
String data=oneDetails.get("_id").toString();
System.out.println(data);

после получения значения преобразуются в тип inter.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...