如何在Java中使用子节点查询MongoDB

时间:2015-04-14 18:42:15

标签: java mongodb child-nodes

我正在尝试用java查询mongodb。我的收藏品的名称是:读取。以下是我要查询的特定文档的示例:

{
"_id" : {
    "d" : "B66929932",
    "r" : "15500304",
    "eT" : ISODate("2014-09-29T12:03:00Z")
},
"v" : 169000,
"iT" : ISODate("2015-04-10T20:42:07.577Z")

}

我正在尝试查询r = 15500304,eT = 2014-09-29T12:03:00Z和v = 169000.我可以很容易地在mongo中执行此操作:

db.reads.find({ "_id.r" : "15500304", "_id.eT" : ISODate("2014-09-29T12:03:00Z"), "$where" : "this.v == 169000;"}).pretty()

我无法弄清楚如何在java中构建它。到目前为止我已经:

DBCollection collection = db.getCollection("reads");
BasicDBObject andQuery = new BasicDBObject();
List<BasicDBObject> obj = new ArrayList<BasicDBObject>();

obj.add(new BasicDBObject("_id.r", "15500304"));
obj.add(new BasicDBObject("_id.eT", "2014-09-29T12:03:00Z"));
obj.add(new BasicDBObject("v", 169000));
andQuery.put("$and", obj);

DBCursor cursor = collection.find(andQuery);
    while(cursor.hasNext()){
        System.out.println(cursor.next());
    }

我的问题是:如何使用这些子节点进行查询并返回匹配的文档?

我无法在网上找到任何明确的建议/示例。任何和所有建议都非常感谢。

1 个答案:

答案 0 :(得分:0)

你很亲密。将您的查询修改为:

DBCollection collection = db.getCollection("reads");
BasicDBObject query = new BasicDBObject();
DateFormat df = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");
String dateInString = "2014-09-29T12:03:00Z";
Date date = df.parse(dateInString);

query.append("status.name", "Expired")
     .append("_id.eT", date)
     .append("v", 169000);

或使用 QueryBuilder

DBObject query = QueryBuilder.start()
                         .put("_id.r").is("15500304")
                         .put("_id.eT").is(date)
                         .put("v").is(169000)
                         .get();

DBCursor cursor = collection.find(query);
while(cursor.hasNext()){
    System.out.println(cursor.next());
}