gpt4 book ai didi

scala - Casbah 中的 Mongodb $elemMatch

转载 作者:可可西里 更新时间:2023-11-01 09:52:54 24 4
gpt4 key购买 nike

我正在使用 Casbah 2.9.2

我的 mongodb 架构如下:

[ _id:“三角形”,信息:[颜色:“红色”,线:“细”,UseID:“1”,SourceId:“2”]]

我希望能够编写一个更新行,首先检查 _id、Color 和 Line 一起是否唯一,如果是则更新 UseID 和 SourceID,否则创建一个新的“信息”条目。这让我从命令行得到了我想要的:

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 没有可用的隐式 View 。涉及默认参数的应用程序发生错误。“信息” $不{ _ $elemMatch {"

所以我想问题是,我什至可以在 Casbah 中从命令行进行更新吗?如果是,怎么办?

谢谢!

最佳答案

所以对于任何关心的人来说,首先我的更新字符串有点偏离,如果“Color”和“Line”不存在但“_id”存在,它会抛出错误。基本上它看起来像 $push with upsetter as true 不会添加到现有的“_id”,所以我在尝试添加条目时遇到重复键错误。但是,这没有实际意义,我想要做的事情的真正解决方案是不使用 Casbah,而是使用 MongoDB Java 驱动程序。然后我能够让 $elemMatch 做我想做的事。

这也可能是我问题的一部分,因为我走了一条不同的路线,所以我没有机会测试它:

“如果您真的觉得需要将++ 与 DSL 和裸匹配混合使用,我们会为 -> 元组对提供附加支持。您应该先调用查询运算符:”

val qMix = ("baz" -> 5) ++ ("foo" $gte 5) ++ ("x" -> "y")
/* error: value ++ is not a member of (java.lang.String, Int)
val qMix = ("baz" -> 5) ++ ("foo" $gte 5) ++ ("x" -> "y") */

运算符与 DSL 运算符的结果链接(顺便说一句,它正确地返回了一个 DBObject):

val qMix = ("foo" $gte 5) ++ ("baz" -> 5) ++ ("x" -> "y")
/* qMix: com.mongodb.casbah.commons.Imports.DBObject =
{ "foo" : { "$gte" : 5} , "baz" : 5 , "x" : "y"} */

发件人:http://api.mongodb.org/scala/casbah/current/tutorial.html

关于scala - Casbah 中的 Mongodb $elemMatch,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13453893/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com