掃二維碼與項(xiàng)目經(jīng)理溝通
我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流
mongodb不支持事務(wù),所以,在你的項(xiàng)目中應(yīng)用時(shí),要注意這點(diǎn)。無論什么設(shè)計(jì),都不要要求mongodb保證數(shù)據(jù)的完整性。

新河網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),新河網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為新河千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢,請找那個(gè)售后服務(wù)好的新河做網(wǎng)站的公司定做!
但是mongodb提供了許多原子操作,比如文檔的保存,修改,刪除等,都是原子操作。
所謂原子操作就是要么這個(gè)文檔保存到Mongodb,要么沒有保存到Mongodb,不會(huì)出現(xiàn)查詢到的文檔沒有保存完整的情況。
考慮下面的例子,圖書館的書籍及結(jié)賬信息。
實(shí)例說明了在一個(gè)相同的文檔中如何確保嵌入字段關(guān)聯(lián)原子操作(update:更新)的字段是同步的。
book = {
_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.findAndModify() 方法來判斷書籍是否可結(jié)算并更新新的結(jié)算信息。
在同一個(gè)文檔中嵌入的 available 和 checkout 字段來確保這些字段是同步更新的:
db.books.findAndModify ( {
query: {
_id: 123456789,
available: { $gt: 0 }
},
update: {
$inc: { available: -1 },
$push: { checkout: { by: "abc", date: new Date() } }
}
} )
用來指定一個(gè)鍵并更新鍵值,若鍵不存在并創(chuàng)建。
{ $set : { field : value } }
用來刪除一個(gè)鍵。
{ $unset : { field : 1} }
$inc可以對文檔的某個(gè)值為數(shù)字型(只能為滿足要求的數(shù)字)的鍵進(jìn)行增減的操作。
{ $inc : { field : value } }
用法:
{ $push : { field : value } }把value追加到field里面去,field一定要是數(shù)組類型才行,如果field不存在,會(huì)新增一個(gè)數(shù)組類型加進(jìn)去。
同$push,只是一次可以追加多個(gè)值到一個(gè)數(shù)組字段內(nèi)。
{ $pushAll : { field : value_array } }
從數(shù)組field內(nèi)刪除一個(gè)等于value值。
{ $pull : { field : _value } }
增加一個(gè)值到數(shù)組內(nèi),而且只有當(dāng)這個(gè)值不在數(shù)組內(nèi)才增加。
刪除數(shù)組的第一個(gè)或最后一個(gè)元素
{ $pop : { field : 1 } }
修改字段名稱
{ $rename : { old_field_name : new_field_name } }
位操作,integer類型
{$bit : { field : {and : 5}}}
> t.find() { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 3 }, { "by" : "jane", "votes" : 7 } ] }
> t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false, true )
> t.find() { "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 4 }, { "by" : "jane", "votes" : 7 } ] }

我們在微信上24小時(shí)期待你的聲音
解答本文疑問/技術(shù)咨詢/運(yùn)營咨詢/技術(shù)建議/互聯(lián)網(wǎng)交流