使用 mongoDB 切换布尔值

Toggle a boolean value with mongoDB

我正在使用 mongoDB 数据库,我想切换 Day 对象内的布尔值存在属性。这是我的工作代码:

exports.modifyPresence = (req, res) => {
  action.getStudentCurrentDay(req.body.hash)
  .then(
    dayId => {
      return Day.findOne({_id: dayId});
    }
  )
  .then(
    day => {
      return Day.findOneAndUpdate({_id: day.id},{$set:{present:!day.present}});
    }
  )
  .then(
    () => res.status(200).json("This is a success")
  )
  .catch(
    (error) => res.status(500).json({error})
  )
}

它正在工作,但我很想调用我的数据库一次并编写如下内容:

exports.modifyPresence = (req, res) => {
  action.getStudentCurrentDay(req.body.hash)
  .then(
    dayId => {
      return Day.findOneAndUpdate({_id: day.id},{$set:{present:!present}});
    }
  )
  .then(
    () => res.status(200).json("This is a success")
  )
  .catch(
    (error) => res.status(500).json({error})
  )
}

有谁知道如何实现对数据库的单次调用并以优雅的方式切换我的布尔值?我不知道如何简化我的代码。

谢谢大家

如果您使用的是 MongoDB 4.2,您可以在更新语句中使用聚合运算符,例如:

.findOneAndUpdate({_id: day.id},[{$set:{present:{$eq:[false,"$present"]}}}]);

这会将 present 设置为 true 如果它是 false,如果它是任何其他值则设置为 false。

您可以使用 update with aggregation pipeline 从 MongoDB v4.2 开始,

  • $not 计算一个布尔值和 returns 相反的布尔值;即当传递一个计算结果为 true 的表达式时,$not returns false;当传递一个计算结果为 false 的表达式时,$not returns true.
return Day.findOneAndUpdate(
  { _id: day.id },
  [
    { $set: { present: { $not: "$present" } } }
  ]
);

Playground