进入MongoDB中文手册(4.2版本)目录
尽管MongoDB支持副本集(从版本4.0开始)和分片群集(从版本4.2开始)的多文档事务,但是在许多情况下,如本页中所述,非规范化数据模型将继续是数据和用例的最佳选择。
模式
在MongoDB中,对单个文档的写操作是原子的。对于必须一起更新的字段,将字段嵌入到同一文档中可确保字段可以自动更新。
例如,考虑一种情况,您需要维护有关书籍的信息,包括付款的可以复印本数量以及当前的付款信息。
书籍的可用复印本和结帐信息应该同步。这样,将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.updateOne()方法对available字段和checkout字段进行原子更新操作:
db.books.updateOne (
{ _id: 123456789, available: { $gt: 0 } },
{
$inc: { available: -1 },
$push: { checkout: { by: "abc", date: new Date() } }
}
)
该操作返回一个文档,其中包含有关操作状态的信息:
{ "acknowledged" : true, "matchedCount" : 1, "modifiedCount" : 1 }
matchedCount字段显示1文档符合更新条件,modifiedCount显示操作已更新1 文档。
如果没有文档符合更新条件,则matchedCountand和modifiedCount将是0,并且将指示您无法找到该书。
进入MongoDB中文手册(4.2版本)目录