使用Java驱动程序,有没有一种简单的方法来获取mongoDB实例中最后插入文档的ID(ObjectID)?
我刚刚意识到你可以这样做:
BasicDBObject doc = new BasicDBObject( "name", "Matt" );
collection.insert( doc );
ObjectId id = (ObjectId)doc.get( "_id" );
Object
到ObjectId
的转换,假设有一个com.mongodb.client.MongoCollection collection
和一个org.bson.Document doc
,您可以执行以下操作:collection.insert(doc);
ObjectId id = doc.getObjectId("_id");
这样做是安全的
doc.set("_id", new ObjectId())
如果您查看驱动程序的代码
if ( ensureID && id == null ){
id = ObjectId.get();
jo.put( "_id" , id );
}
public static ObjectId get(){
return new ObjectId();
}
我不了解Java驱动程序,但为了后人,可以运行getLastError命令来获取写操作的_id,甚至是upsert(截至1.5.4版本)。
在将文档插入到MongoDB集合后,成功插入应更新必需字段(即_id)。您可以查询已插入的对象以获取_id。
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));
}
而且这个方法会为我们设置id
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的子类,它将为我们设置一个ID。
我认为答案是"不可以"。
你可以手动提供_id
,或者实现CollectibleCodec
机制(这正是BasicBDDocument
所做的)。但是所有这些解决方案都涉及在客户端生成ID。
话虽如此,我认为在客户端生成_id
没有任何问题。
这是插入操作:
DBCollection table1 = db.getCollection("Collection name");
BasicDBObject document = new BasicDBObject();
document.put("_id",value);
document.put("Name", name);
table1.insert(document);
插入后,您可以获取最后插入的ID:
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);
获取值后转换为整数类型。