开发者社区 问答 正文

关于MongoDB中两张表查询问题

1
我需要根据一级和二级类别的name查询应用程序表的数据。但每次查询的都有用两个while循环,

DBCursor cursor1=null;
DBCursor cursor=this.dao.getDBCursor(offset, pageSize, db, "thirdCategory", sort);
DBObject query1 = new BasicDBObject();
while (cursor.hasNext()) {
@SuppressWarnings("unchecked")
Map map1 = cursor.next().toMap();
System.out.println(map1);
if(map1!=null){
query1.put("categoryId",map1.get("categoryId"));
cursor1=this.dao.getDBCursor(offset, pageSize, query1, "ucApp", sort);
while (cursor1.hasNext()) {
@SuppressWarnings("unchecked")
Map map2 = cursor1.next().toMap();

if(map2!=null){
map2.putAll(map1);
list.add(map2);
}
}
}
}
Map map3 = new HashMap();
map3.put("total", cursor1 == null ? 0 : cursor1.count());
map3.put("data", list);
return map3;

导致我分页不行。

展开
收起
落地花开啦 2016-02-28 17:14:53 3619 分享 版权
1 条回答
写回答
取消 提交回答
  • 1.如果需要的数据实时性要求比较高,可以用mongodb做队列服务使用 程序代码实时处理数据 2.合并user_register user_login 到一个collection 然后再mapreduce 3.使用dbref关联两个collection 然后再mapreduce

    答案来源于网络

    2019-10-08 15:41:33
    赞同 展开评论