0
点赞
收藏
分享

微信扫一扫

Mongoose 解决 Query was already executed 问题

code_balance 2022-07-27 阅读 62

本文已整理到 Github,地址 👉 ​​blog​​。


我希望我的内容可以帮助你。现在我专注于前端领域,但我也将分享我在有限的时间内看到和感受到的东西。

当给定查询执行两次时,Mongoose 会抛出 "Query was already executed"(查询已执行)错误。对此最常见的解释是您正在混合 ​​await​​ 和回调。

await Model.updateMany({}, { $inc: { count: 1 } }, function (err) {})
// "MongooseError: Query was already executed"

这是因为 Mongoose 在收到回调或 ​​await​​​ 时执行查询。如果您使用 ​​await​​ 并传递回调,则此查询将执行两次。

或者:

Model.updateMany({}, { $inc: { count: 1 } }, function (err) {}).then(() => {})

此查询执行两次。一次是因为回调,一次是因为 ​​then()​​ 方法。

解决方案是跳过传递回调。在 Mongoose 中不需要回调,因为 Mongoose 支持 ​​promises​​​ 和 ​​async/await​​。

await Model.updateMany({}, { $inc: { count: 1 } })
// or
Model.updateMany({}, { $inc: { count: 1 } }).then(() => {})

但如果我们想执行两次查询呢?可以使用 ​​clone()​​ 方法:

let query = Model.findOne()

await query

// 抛出 "MongooseError: Query was already executed" 错误
await query

// ✅
await query.clone()

举报

相关推荐

0 条评论