我有以下数据结构
{
"_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 错误还是 morphia 错误?我有什么解决方法来获取匹配的文档吗?
- 请注意,在现实世界的实践中,我有 2 个 elemMatch 条件,因此我必须使用“elemMatch”,而不是“点符号”匹配。以上只是为了简化我的案例以便于查看。
- 我正在运行 Mongodb 2.4.6 和 Morphia 1.2.3
谢谢!