开发者社区> 问答> 正文

nodejs mongodb express如何将一对多的两个表合并为一个json对象返回

第一次用nodejs mongodb express做项目
两个表,部门、人员。人员里面有一个属性存放部门id
现在想将这两个表的结果拼成如下格式返回给浏览器:

    [
        {
            name:'部门名称',
            people:[人员对象数组]
        },
        {第二个部门}
        ...
    ]

首先查出所有的部门,在回调里面获得到了所有部门的数组,但是接下来就没办法了,根据部门查找到的人员数组必须在下级查询的回调里面才能获得,想不到什么办法可以用来添加到上级回调的部门数组里面。

(伪代码):
    db.部门.find({},function(err,objs1){
        for(let i of objs1){
            db.人员.find({部门id:i._id},function(err,objs2){
                i.people=objs2;
                //由于异步的问题,在这里修改objs1显然是没用的,然后就想不到该怎么做了
            });
        }
        res.send(objs1);
    })

也查了很多东西,promise、generator、async,也自己写了函数试验,但是对于数据库自带的api,他就是用的原始的异步回调的方式,求教改如何处理?

展开
收起
蛮大人123 2016-06-14 15:35:02 3701 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    有两个方法,一是使用 mongoose 的 ref 来组织部门数据,另外一个办法是分别读取部门和人员信息,再对应后组装数据。
    使用 ref
    在人员的 Schema 里,做如下的设置:

    var PeopleSchema = new mongoose.Schema({
      depart: {
        type: mongoose.Schema.ObjectId,
        ref: 'Depart'
      }
    });

    然后,在获取人员信息的时候,使用 populate 方法:

    People.find().populate('depart').exec(function(err, docs){
       //...
    });

    你可以打印一下结构看一下具体的数据组织。
    分别查询再组装
    大概实现的代码如下:

    var peoples = null, departs = null, flag = 0;
    People.find().exec(function(err, docs){
      if(err) {
        // handle error
      }
      peoples = docs;
      goon(++flag);
    });
    Depart.find().exec(function(err, docs){
      if(err) {
        // handle error
      }
    
      departs = docs;
      goon(++flag);
    });
    
    function goon() {
      if(2 !== flag) return;
    
      //organize your data with peoples and departs
    }
    2019-07-17 19:37:53
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Data as a Service - 数据即服务 -- MongoDB⾼级应⽤模式 立即下载
开源数据库 MongoDB 专场 MongoDB疑难杂症分析及优化 立即下载
饿了么高级架构师陈东明:MongoDB是如何逐步提高可靠性的 立即下载