java – 将数组中的子文档作为DBObject检索

前端之家收集整理的这篇文章主要介绍了java – 将数组中的子文档作为DBObject检索前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我对MongoDB很新,我正在使用 Java驱动程序.我有这个文件结构:
{ "_id" : ObjectId("4f7d2ba6fd5a306d82687d48"),"room" : "Den" }
{ "_id" : ObjectId("4f7d2baafd5a306d82687d49"),"room" : "Foyer" }
{ "_id" : ObjectId("4f7d2fdcfd5a306d82687d4a"),"room" : "Master Bedroom" }
{ "_id" : ObjectId("4f7d301afd5a306d82687d4b"),"room" : "Guest Bedroom" }
{ "_id" : ObjectId("4f7d2b98fd5a306d82687d47"),"code" : "A","lights" : [ { "name" : "Overhead","code" : "1" } ],"room" : "Kitchen" }

最后一行对于说明我想做什么特别有意义.每个文件都是一个房间,可能有一个“灯”键对应一个子文档数组的值.从建模的角度来说,我有一个房子,它有0-n个房间,每个房间都有0-n个灯.我想在Java中做的是将房间的名称作为参数,并返回与灯列中的子文档相对应的DBObject集合 – “给我所有房间的灯”厨房“,例如.

到目前为止,我以TDD风格逐步进行,我构造了这个查询

public static final String ROOM_KEY = "room";

public static final String EQUALS_KEY = "$eq";

private BasicDBObject buildRoomNameQuery(String roomName) {

    BasicDBObject myQuery = new BasicDBObject();
    myQuery.put(ROOM_KEY,new BasicDBObject(EQUALS_KEY,roomName));

    return myQuery;
}

我意识到这会让我得到我通过的房间名称的整个房间文件.我有点坚持从这里开始最好的方法是获得我想要的东西.我甚至可以通过一个简单的查询来做甚么,或者我必须检索数组并在代码中迭代它,将元素转换为DBObject?我也可以为我的目的提出更好的文件结构建议 – 我没有以任何方式结婚这个结构.

对于一些观点,我非常精通sql和传统关系数据库,如果这有助于解释性类比.另外,如果我在屠杀MongoDB术语,请更正我.提前致谢.

解决方法

所以,你可以这样做:
DBCollection coll = db.getCollection("test");
BasicDBObject query = new BasicDBObject("room","Kitchen"); 

// optional,limit the fields to only have the lights field
BasicDBObject fields = new BasicDBObject("lights",1).append("_id",false);
DBCursor curs = coll.find(query,fields);
while(curs.hasNext()) {
  DBObject o = curs.next();

  // shows the whole result document
  System.out.println(o.toString());
  BasicDBList lights = (BasicDBList) o.get("lights");

  // shows the lights array -- this is actually a collection of DBObjects
  System.out.println(lights.toString());

  // optional: break it into a native java array
  BasicDBObject[] lightArr = lights.toArray(new BasicDBObject[0]);
  for(BasicDBObject dbObj : lightArr) {
    // shows each item from the lights array
    System.out.println(dbObj);
  }
}

此外,我建议在Java驱动程序中使用QueryBuilder – 比从DBObjects创建查询更简洁.更好的是,查看Morphia,它是使用Java驱动程序的对象映射器.它本身支持具有列表的实体模型,并将它们序列化/反序列化为Mongo,而不需要处理DBObject的东西.

猜你在找的Java相关文章