这里是一般 Node mongodb 问题。
我有这个功能:
static addSpaceToCreator = ( userId, spaceId, callback ) => {
const db = getDb();
db.collection( process.env.SPACECOLLECTION ).updateOne( { _id: ObjectId( spaceId ) }, { $push: { challengers: ObjectId( userId ) } } );
db.collection( process.env.USERSCOLLECTION ).updateOne( { _id: ObjectId( userId ) }, { $push: { spaces: ObjectId( spaceId ) } } ).then( r => callback( r ) ).catch( e => callback( e ) );
};
问题: 有没有更好的方法来进行这样的多次更改?我无法使用批量,因为文档位于不同的集合中。即使我没有回调,是否有更好的方法来进行 2 次 .collection 旅行?
感谢您的宝贵时间
最佳答案
使用Promise.all
等待并行查询的结果,如下所示:
static addSpaceToCreator = ( userId, spaceId ) => {
const db = getDb();
return Promise.all([
db.collection( process.env.SPACECOLLECTION ).updateOne( { _id: ObjectId( spaceId ) }, { $push: { challengers: ObjectId( userId ) } } ),
db.collection( process.env.USERSCOLLECTION ).updateOne( { _id: ObjectId( userId ) }, { $push: { spaces: ObjectId( spaceId ) } } ));
]);
};
并像这样使用它:
await addSpaceToCreator(4, 2);
关于node.js - 如何高效地进行多次 MongoDB 旅行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59664195/