MongoDb的更新操作

mongodb更新有兩個(gè)命令:

1).update()命令

db.collection.update( criteria, objNew, upsert, multi )

criteria : update的查詢條件,類似sql update查詢內(nèi)where后面的
objNew : update的對象和一些更新的操作符(如$,$inc...)等,也可以理解為sql update查詢內(nèi)set后面的
upsert : 這個(gè)參數(shù)的意思是捆探,如果不存在update的記錄许蓖,是否插入objNew,true為插入在验,默認(rèn)是false,不插入秉颗。
multi : mongodb默認(rèn)是false,只更新找到的第一條記錄,如果這個(gè)參數(shù)為true,就把按條件查出來多條記錄全部更新巨朦。

例:
db.test0.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一條記錄
db.test0.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
db.test0.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加進(jìn)去了第一條
db.test0.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加進(jìn)去了
db.test0.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
db.test0.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一條

2).save()命令

db.collection.save( x )

x就是要更新的對象,只能是單條記錄剑令。

如果在collection內(nèi)已經(jīng)存在一個(gè)和x對象相同的"_id"的記錄糊啡。mongodb就會(huì)把x對象替換collection內(nèi)已經(jīng)存在的記錄,否則將會(huì)插入x對象吁津,如果x內(nèi)沒有_id,系統(tǒng)會(huì)自動(dòng)生成一個(gè)再插入棚蓄。相當(dāng)于上面update語句的upsert=true,multi=false的情況。

例:
db.test0.save({count:40,test1:"OK"}); #_id系統(tǒng)會(huì)生成
db.test0.save({_id:40,count:40,test1:"OK"}); #如果test0內(nèi)有_id等于40的碍脏,會(huì)替換梭依,否則插入。

mongodb的更新操作符:

  1. $inc

用法:{ $inc : { field : value } }

意思對一個(gè)數(shù)字字段field增加value典尾,例:

db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 16, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $inc : { "count" : 1 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 17, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $inc : { "count" : 2 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 19, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $inc : { "count" : -1 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "TESTTEST", "test2" : "OK", "test3" : "TESTTEST", "test4" : "OK", "test5" : "OK" }

  1. $set

用法:{ $set : { field : value } }

就是相當(dāng)于sql的set field = value役拴,全部數(shù)據(jù)類型都支持$set。例:

db.test0.update( { "_id" : 15 } , { $set : { "test1" : "testv1","test2" : "testv2","test3" : "testv3","test4" : "testv4" } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : "testv1", "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

  1. $unset

用法:{ $unset : { field : 1} }

顧名思義钾埂,就是刪除字段了河闰。例:

db.test0.update( { "_id" : 15 } , { $unset : { "test1":1 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test2" : "testv2", "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $unset : { "test2": 0 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test3" : "testv3", "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $unset : { "test3":asdfasf } } );
Fri May 14 16:17:38 JS Error: ReferenceError: asdfasf is not defined (shell):0

db.test0.update( { "_id" : 15 } , { $unset : { "test3":"test" } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test4" : "testv4", "test5" : "OK" }

沒看出field : 1里面的1是干什么用的,反正只要有東西就行勃教。

  1. $push

用法:{ $push : { field : value } }

把value追加到field里面去淤击,field一定要是數(shù)組類型才行,如果field不存在故源,會(huì)新增一個(gè)數(shù)組類型加進(jìn)去污抬。例:

db.test0.update( { "_id" : 15 } , { $set : { "test1" : ["aaa","bbb"] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb" ], "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $push : { "test1": "ccc" } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $push : { "test2": "ccc" } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $push : { "test1": ["ddd","eee"] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }5) $pushAll

用法:{ $pushAll : { field : value_array } }

同$push,只是一次可以追加多個(gè)值到一個(gè)數(shù)組字段內(nèi)。例:

db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $pushAll : { "test1": ["fff","ggg"] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "aaa", "bbb", "ccc", [ "ddd", "eee" ], "fff", "ggg" ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

  1. $addToSet

用法:{ $addToSet : { field : value } }

增加一個(gè)值到數(shù)組內(nèi)绳军,而且只有當(dāng)這個(gè)值不在數(shù)組內(nèi)才增加印机。例:

db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"aaa",
"bbb",
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444",
"555"
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": {$each : ["444","555"] } } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"aaa",
"bbb",
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444",
"555"
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": ["444","555"] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"aaa",
"bbb",
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444",
"555",
[
"444",
"555"
]
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
db.test0.update( { "_id" : 15 } , { $addToSet : { "test1": ["444","555"] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"aaa",
"bbb",
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444",
"555",
[
"444",
"555"
]
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

  1. $pop

刪除數(shù)組內(nèi)的一個(gè)值

用法:
刪除最后一個(gè)值:{ $pop : { field : 1 } }刪除第一個(gè)值:{ $pop : { field : -1 } }

注意,只能刪除一個(gè)值门驾,也就是說只能用1或-1射赛,而不能用2或-2來刪除兩條。mongodb 1.1及以后的版本才可以用奶是,例:

db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"bbb",
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444"
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
db.test0.update( { "_id" : 15 } , { $pop : { "test1": -1 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [
"ccc",
[
"ddd",
"eee"
],
"fff",
"ggg",
[
"111",
"222"
],
"444"
], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }
db.test0.update( { "_id" : 15 } , { $pop : { "test1": 1 } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
"test5" : "OK" }

  1. $pull

用法:$pull : { field : value } }

從數(shù)組field內(nèi)刪除一個(gè)等于value值楣责。例:

db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", "ggg", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4",
"test5" : "OK" }

db.test0.update( { "_id" : 15 } , { $pull : { "test1": "ggg" } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
: "OK" }

  1. $pullAll

用法:{ $pullAll : { field : value_array } }

同$pull,可以一次刪除數(shù)組內(nèi)的多個(gè)值。例:

db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ "ccc", [ "ddd", "eee" ], "fff", [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5"
: "OK" }

db.test0.update( { "_id" : 15 } , { $pullAll : { "test1": [ "ccc" , "fff" ] } } );
db.test0.find( { "_id" : 15 } );
{ "_id" : { "floatApprox" : 15 }, "count" : 18, "test1" : [ [ "ddd", "eee" ], [ "111", "222" ] ], "test2" : [ "ccc" ], "test4" : "testv4", "test5" : "OK" }

  1. $ 操作符

$是他自己的意思聂沙,代表按條件找出的數(shù)組里面某項(xiàng)他自己秆麸。呵呵,比較坳口及汉【谌ぃ看一下官方的例子:

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 } ] }

需要注意的是,$只會(huì)應(yīng)用找到的第一條數(shù)組項(xiàng)坷随,后面的就不管了房铭。還是看例子:

t.find();
{ "_id" : ObjectId("4b9e4a1fc583fa1c76198319"), "x" : [ 1, 2, 3, 2 ] }
t.update({x: 2}, {$inc: {"x.$": 1}}, false, true);
t.find();

還有注意的是$配合$unset使用的時(shí)候驻龟,會(huì)留下一個(gè)null的數(shù)組項(xiàng),不過可以用{$pull:{x:null}}刪除全部是null的數(shù)組項(xiàng)缸匪。例:

t.insert({x: [1,2,3,4,3,2,3,4]})
t.find()
{ "_id" : ObjectId("4bde2ad3755d00000000710e"), "x" : [ 1, 2, 3, 4, 3, 2, 3, 4 ] }
t.update({x:3}, {$unset:{"x.$":1}})
t.find()
{ "_id" : ObjectId("4bde2ad3755d00000000710e"), "x" : [ 1, 2, null, 4, 3, 2, 3, 4 ] }

{ "_id" : ObjectId("4b9e4a1fc583fa1c76198319"), "x" : [ 1, 3, 3, 2 ] }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末翁狐,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子豪嗽,更是在濱河造成了極大的恐慌谴蔑,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件龟梦,死亡現(xiàn)場離奇詭異隐锭,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)计贰,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門钦睡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人躁倒,你說我怎么就攤上這事荞怒。” “怎么了秧秉?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵褐桌,是天一觀的道長。 經(jīng)常有香客問我象迎,道長荧嵌,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任砾淌,我火速辦了婚禮啦撮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘汪厨。我一直安慰自己赃春,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布劫乱。 她就那樣靜靜地躺著织中,像睡著了一般。 火紅的嫁衣襯著肌膚如雪衷戈。 梳的紋絲不亂的頭發(fā)上抠璃,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機(jī)與錄音脱惰,去河邊找鬼。 笑死窿春,一個(gè)胖子當(dāng)著我的面吹牛拉一,可吹牛的內(nèi)容都是我干的采盒。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼蔚润,長吁一口氣:“原來是場噩夢啊……” “哼磅氨!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起嫡纠,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤烦租,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后除盏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體叉橱,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年者蠕,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了窃祝。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡踱侣,死狀恐怖粪小,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情抡句,我是刑警寧澤探膊,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站待榔,受9級(jí)特大地震影響逞壁,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜究抓,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一猾担、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧刺下,春花似錦绑嘹、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至畅卓,卻和暖如春擅腰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背翁潘。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工趁冈, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓渗勘,卻偏偏與公主長得像沐绒,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子旺坠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容