mongo Java按数组搜索

时间:2016-10-27 10:36:14

标签: java mongodb mongodb-query mongo-java-driver

我和mongo一起工作了几个月,现在我一直在努力。

以下是我的数据库的文档示例:

"_id" : ObjectId("5732d96fed40761e640a3f3e"),
"_familyId" : "12345",
"_applications" : [
{
    "_applicationRID" : "123456",
    "_applicationDate" : "01012000",
    "_isRepresentative" : false,
    "_applicationId" : {
            "CC" : "AB",
            "SN" : "123456789",
            "KC" : "A"
    },
    "_publications" : [
    {
        "_publicationRID" : "123456789",
        "_publicationDate" : "01012000",
        "_flaId" : "AB123456789A",
        "_publicationId" : {
                "CC" : "AB",
                "SN" : "1234567",
                "KC" : "B"
        }, 

[...] 

现在,我试图在数组上用Java做collection.find()。 我知道_publicationId中包含的所有字段,我需要在_publicationId上搜索,因为它有索引但不包含其中的字段。

在shell中它将是:

db.collection.find({
    "_applications._publications._publicationId": {
        "CC": "AB",
        "SN": "1234567",
        "KC": "B"
    }
})

这很好。

使用java,我找不到合适的语法:

collection.find("_applications._publications._publicationId",  ??? )

1 个答案:

答案 0 :(得分:0)

您应该尝试查询下一个类型,它实际上与您在java中的查询完全等效:

DBObject query = new BasicDBObject(
    "_applications._publications._publicationId",
    new BasicDBObject("CC", "AB").append("SN", "1234567").append("KC", "B")
);
DBCursor cursor = collection.find(query);