MongoDB elemMatch子文档

时间:2013-09-13 16:28:13

标签: mongodb morphia

我有以下数据结构

{
    "_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?我有没有办法解决匹配的文件?

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

谢谢!

1 个答案:

答案 0 :(得分:2)

为时已晚,但也许其他人可以发现它很方便。

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

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