原子操作的模型数据
在本页面
Pattern
在 MongoDB 中,进行写操作,例如db.collection.update(),db.collection.findAndModify(),db.collection.remove()在单个文档的级别上是原子的。对于必须一起更新的字段,将字段嵌入到同一文档中可确保可以自动更新字段。
例如,考虑一种情况,您需要维护有关书籍的信息,包括可用于结帐的副本数量以及当前的结帐信息。
书籍的可用副本和结帐信息应同步。这样,将available
字段和checkout
字段嵌入同一文档中可确保您可以自动更新两个字段。
{
_id: 123456789,
title: "MongoDB: The Definitive Guide",
author: [ "Kristina Chodorow", "Mike Dirolf" ],
published_date: ISODate("2010-09-24"),
pages: 216,
language: "English",
publisher_id: "oreilly",
available: 3,
checkout: [ { by: "joe", date: ISODate("2012-10-15") } ]
}
然后,要使用新的结帐信息进行更新,可以使用db.collection.update()方法原子地更新available
字段和checkout
字段:
db.books.update (
{ _id: 123456789, available: { $gt: 0 } },
{
$inc: { available: -1 },
$push: { checkout: { by: "abc", date: new Date() } }
}
)
该操作返回一个WriteResult()对象,该对象包含有关操作状态的信息:
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })