我正在使用 Casbah 2.9.2
我的 mongodb 架构如下所示:
[_id:“三角形”,信息:[颜色:“红色”,线条:“细”,UseID:“1”,SourceId:“2”]]
我希望能够编写一个更新行,首先检查 _id、Color 和 Line 是否一起唯一,如果是,则更新 UseID 和 SourceID,否则创建一个新的“Info”条目。这让我从命令行得到了我想要的东西:
db.shapes.update( { _id : 'Triangle', Info : { $not : { $elemMatch : { Color : 'Red', Line : 'Thick' } } } }, { $push : { Info : { Color : 'Red', Line : 'Thick', UseID : '2', SourceId : '3' } } }, true)
给我这个条目:
[ _id : "Triangle", Info : [ { Color : "Red", Line : "Thin", UseID : "1", SourceId : "2" }, { Color : "Red", Line : "Thick", UseID : "2", SourceId : "3" } ] ]
但是,当我为 Scala 翻译成 Casbah 时,它不会:
shapesCollection.update( { "_id" -> shape, "Info" $not { _ $elemMatch { "Color" -> color, "Line" -> line } } }, { $push -> { "Info" -> { "Color" -> color, "Line" -> line, "UseId" -> useId, "SourceId" -> srcId } } }, true )
第一个抱怨(来自 IntelliJ)是它希望所有的 ',' 都是 ';',我觉得这是不正确的,但为了调试,我必须这样做,这让我想到了第二个错误:
“错误:(java.lang.String, java.lang.String) => com.mongodb.casbah.query.Imports.DBObject 没有可用的隐式视图。涉及默认参数的应用程序中发生错误。“信息”$not { _ $elemMatch {"
所以我想问题是,我什至可以从 Casbah 的命令行进行更新吗?如果是这样,怎么做?
谢谢!