我和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", ??? )
答案 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);