【发布时间】:2015-08-17 03:21:31
【问题描述】:
使用 mongodb java 驱动程序版本 3(特别是 v3.0.1)更新插入文档的惯用方法是什么?
我们有一个会话集合,当一个新的会话被创建或修改时,我们希望在一个操作中更新它 - 而不是必须查询一个文档是否存在然后插入或替换。
我们旧的 upsertion 代码使用了 scala 驱动程序 casbah 2.7.3。它看起来像:
import com.mongodb.casbah.MongoCollection
import com.mongdb.DBObject
val sessionCollection: MongoCollection = ...
val sessionKey: String = ...
val sessionDocument: DBObject = ... // Either create a new one, or find and modify an existing one
sessionCollection.update(
"_id" -> sessionKey,
sessionDocument
upsert = true
)
在我们当前的项目中,我们只使用普通的 java 3.0.1 驱动程序,并且我们使用 BsonDocument 而不是 DBObject 以使其更安全。我试图用类似的东西替换上面的内容:
import com.mongodb.client.MongoCollection
val sessionCollection: MongoCollection = ...
val sessionKey: String = ...
val sessionDocument: BsonDocument = // Either create a new one, or find and modify an existing one
val updateOptions = new UpdateOptions
updateOptions.upsert(true)
sessionCollection.updateOne(
"_id" -> new BsonString(sessionKey),
sessionDocument,
updateOptions
)
这会引发错误“java.lang.IllegalArgumentException: Invalid BSON field name ...”。 this question 中涵盖了该错误,但该问题中的操作并未尝试在一个操作中进行更新 - 他们使用上下文来决定是否替换/更新/插入等...
我对 scala 或 java 中的代码示例很满意。
谢谢!
【问题讨论】:
标签: java mongodb scala mongodb-java casbah