我正在对Scala和Cashbah进行更新查询。当我写这个..。
val query = MongoDBObject({"_id" -> uri.toString})
val update: DBObject =
$set("uDate" -> new DateTime) ++
$addToSet("appearsOn") $each(sourceToAppend:_*) ++
$addToSet("hasElements") $each(elementsToAppend:_*) ++
$addToSet("hasTriples") $each (triplesToAppend:_*)
OntologyDocument.dao.collection.update(query, update, upsert = true)...it给了我一个这样的编译错误。但如果我这样写的话..。
No implicit view available from Object{def $each(target: Array[Any]): com.mongodb.casbah.commons.Imports.DBObject; def $each(target: Any*): com.mongodb.casbah.commons.Imports.DBObject} => com.mongodb.casbah.commons.Imports.DBObject....then编译并成功运行。
val query = MongoDBObject({"_id" -> uri.toString})
val setOps1 = $addToSet("appearsOn") $each(sourceToAppend:_*)
val setOps2 = $addToSet("hasElements") $each(elementsToAppend:_*)
val setOps3 = $addToSet("hasTriples") $each (triplesToAppend:_*)
val update: DBObject = $set("uDate" -> new DateTime) ++ setOps1 ++ setOps2 ++ setOps3
OntologyDocument.dao.collection.update(query, update, upsert = true)我不明白。
为什么第一个不编译,或者第二个不编译?
我错过了Scala吗?
发布于 2013-06-25 15:51:30
这是由于dsl是如何实现的,以及$each的链接。核心问题是,我认为$addToSet不会像预期的那样合并:
val setOps1 = $addToSet("appearsOn") $each(sourceToAppend:_*)
val setOps2 = $addToSet("hasElements") $each(elementsToAppend:_*)
setOps1 ++ setOps2
DBObject = { "$addToSet" : { "hasElements" : { "$each" : [ "another" , "list"]}}}似乎MongoDBObject ++不递归地合并。
https://stackoverflow.com/questions/17125352
复制相似问题