Javascript 节点MongoDB循环通过集合';s第一条记录并将其推入数组
我正在尝试按数字集合名称获取用户名列表。我已经创建了这个查询,看起来工作正常,但它并没有进入数组,所以我可以返回整个数据作为api的响应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)
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
返回集合名称,请接受我已修复的编辑版本