gpt4 book ai didi

MongoDB elemMatch 子文档

转载 作者:可可西里 更新时间:2023-11-01 09:45:17 26 4
gpt4 key购买 nike

我有以下数据结构

{
"_id" : ObjectId("523331359245b5a07b903ccc"),
"a" : "a",
"b" : [
{
"c" : {
"_id" : ObjectId("5232b5090364678515db9a82"),
"d" : "d1"
}
},
{
"c" : {
"_id" : ObjectId("5232b5090364678515db9a83"),
"d" : "d2"
}
}
]
}

对于以下查询,mongo 返回

> db.test.find({b : {$elemMatch : {'c.d': 'd1'}}}).count();
1
> db.test.find({b : {$elemMatch : {c: {d: 'd1'}}}}).count();
0

不幸的是,对于下面的语句

B b = new B();
C c = new C();
b.c = c;
b.c.d = "d1";
createQuery().field("b").hasThisElement(b).asList();

Morphia 生成 db.test.find({b : {$elemMatch : {c: {d: 'd1'}}}}) 返回 0 个匹配项。

这是一个 mongo bug 还是 morphia bug?有什么解决方法可以让我获得匹配的文档吗?

  • 请注意,在现实世界的实践中,我有 2 个条件用于 elemMatch,因此我必须使用“elemMatch”,而不是“点符号”匹配。以上只是为了简化我的案例,方便查看。
  • 我正在运行 Mongodb 2.4.6 和 Morphia 1.2.3

谢谢!

最佳答案

为时已晚,但也许其他人可以找到它。

我找到了解决方案 https://groups.google.com/forum/#!topic/morphia/FlEjBoSqkhg

updateQuery.filter("b elem",
BasicDBObjectBuilder.start("c.d", "d1").get());

关于MongoDB elemMatch 子文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18791045/

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