Javascript 节点MongoDB循环通过集合';s第一条记录并将其推入数组

Javascript 节点MongoDB循环通过集合';s第一条记录并将其推入数组,javascript,node.js,mongodb,express,Javascript,Node.js,Mongodb,Express,我正在尝试按数字集合名称获取用户名列表。我已经创建了这个查询,看起来工作正常,但它并没有进入数组,所以我可以返回整个数据作为api的响应 router.get('/chat-logs', async (req, res) => { const collections = Object.keys(db.db.collections); MongoClient.connect(url, { useUnifiedTopology: true }, function(err, dbm)

我正在尝试按数字集合名称获取用户名列表。我已经创建了这个查询,看起来工作正常,但它并没有进入数组,所以我可以返回整个数据作为api的响应

router.get('/chat-logs', async (req, res) => {
  const collections = Object.keys(db.db.collections);

  MongoClient.connect(url, { useUnifiedTopology: true }, function(err, dbm) {
    if (err) throw err;
    var dbo = dbm.db('dbname');
    let collections = dbo
      .listCollections()
      .toArray()
      .then(data => {
        let names = [];
        forEach(data, function(e) {
          let { name } = e;
          if (!isNaN(name)) {
            dbo.collection(name).findOne({}, function(err, result) {
              if (err) throw err;
                names[name] = `${result.first_name} ${result.last_name}`;
            });
          }
        });
        console.log(names)
        res.send(names);
      });
  });
});
正如您所看到的,我正在获取所有集合名称,因为聊天日志与它们对应的ID一起存储为一个集合,我正在遍历它们并获取它们的最后字段。最后,我尝试将它推送到names[]数组中,以便收集它们并发送响应。问题是数组在查询范围之外仍然为空。我有点被困在这一点上,我想知道是否有更简单的方法来获取所有集合,并将它们的最后字段作为一个数组,如果没有,那么我如何解决这个问题

谢谢

请参见

您可以这样做:

router.get('/chat-logs', async (req, res) => {
  const collections = Object.keys(db.db.collections);

  MongoClient.connect(url, { useUnifiedTopology: true }, function(err, dbm) {
    if (err) throw err;
    var dbo = dbm.db('dbname');
    let collections = dbo
      .listCollections()
      .toArray()
      .then(data => {
        let names = [];
        i = 0;
        data.forEach(function(e) {
          let { name } = e;
          if (!isNaN(name)) {
            dbo.collection(name).findOne({}, function(err, result) {
              if (err) throw err;
              names.push(`${result.first_name} ${result.last_name}`);
              i=i+1;
              if(i>(names.length-1)){
                // all callbacks have finished. 
                console.log(names)
                res.send(names);
              }
            });
          }
        });

      });
  });
});

什么是forEach?@CodyG 循环遍历数字集合名称我看不到它的定义,可以添加它吗?它在那里,
collections=dbo.listCollections().toArray()。然后(data=>{
forEach在哪里定义?我在代码中看到了它。这是您正在调用的函数-
names处有错误。length
返回集合名称,请接受我已修复的编辑版本