gpt4 book ai didi

node.js - 如何高效地进行多次 MongoDB 旅行

转载 作者:太空宇宙 更新时间:2023-11-03 23:50:25 24 4
gpt4 key购买 nike

这里是一般 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/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com