這篇文章主要介紹MongoDB更新數(shù)據(jù)的方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
成都創(chuàng)新互聯(lián)專(zhuān)注于扎賚諾爾網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供扎賚諾爾營(yíng)銷(xiāo)型網(wǎng)站建設(shè),扎賚諾爾網(wǎng)站制作、扎賚諾爾網(wǎng)頁(yè)設(shè)計(jì)、扎賚諾爾網(wǎng)站官網(wǎng)定制、小程序開(kāi)發(fā)服務(wù),打造扎賚諾爾網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供扎賚諾爾網(wǎng)站排名全網(wǎng)營(yíng)銷(xiāo)落地服務(wù)。
Mongodb更新有兩個(gè)命令:update、save。
1.1update命令
update命令格式:
db.collection.update(criteria,objNew,upsert,multi)
參數(shù)說(shuō)明:
criteria:查詢(xún)條件。
objNew:update對(duì)象和一些更新操作符。
upsert:如果不存在update的記錄,是否插入objNew這個(gè)新的文檔,true為插入,默認(rèn)為false,不插入。
multi:默認(rèn)是false,只更新找到的第一條記錄。如果為true,把按條件查詢(xún)出來(lái)的記錄全部更新。
示例:
> db.classes.insert({"name":"c1","count":30}) > db.classes.insert({"name":"c2","count":30}) > db.classes.find() { "_id" : ObjectId("5030f3a3721e16c4ab180cd9"), "name" : "c1", "count" : 30 } { "_id" : ObjectId("5030f3ab721e16c4ab180cda"), "name" : "c2", "count" : 30 } >
示例1:把count大于20的class name修改為c3
> db.classes.update({"count":{$gt:20}},{$set:{"name":"c3"}}) > db.classes.find() { "_id" : ObjectId("5030f3a3721e16c4ab180cd9"), "name" : "c3", "count" : 30 } { "_id" : ObjectId("5030f3ab721e16c4ab180cda"), "name" : "c2", "count" : 30 } >
由于沒(méi)有指定upsert和multi的值,所以全部默認(rèn)為false,由結(jié)果可以看出,只修改了第一條符合條件的記錄。
示例2:把count大于20的class name修改為c4,設(shè)置multi為true
> db.classes.update({"count":{$gt:20}},{$set:{"name":"c4"}},false,true) > db.classes.find() { "_id" : ObjectId("5030f3a3721e16c4ab180cd9"), "name" : "c4", "count" : 30 } { "_id" : ObjectId("5030f3ab721e16c4ab180cda"), "name" : "c4", "count" : 30 } >
由于指定了multi為true,所以對(duì)兩條符合條件的記錄都進(jìn)行了更新。
示例3: 把count大于50的class name修改為c5,設(shè)置upsert為true
> db.classes.update({"count":{$gt:50}},{$set:{"name":"c5"}},true,false) > db.classes.find() { "_id" : ObjectId("5030f3a3721e16c4ab180cd9"), "name" : "c4", "count" : 30 } { "_id" : ObjectId("5030f3ab721e16c4ab180cda"), "name" : "c4", "count" : 30 } { "_id" : ObjectId("5030f589ce8fa8884e6cd441"), "name" : "c5" } >
在集合中沒(méi)有count大于50的記錄,但是由于指定了upsert為true,如果找不到則會(huì)插入一條新記錄。
1.2save命令
Mongodb另一個(gè)更新命令是save,格式如下:
db.collection.save(obj)
obj代表需要更新的對(duì)象,如果集合內(nèi)部已經(jīng)存在一個(gè)和obj相同的"_id"的記錄,Mongodb會(huì)把obj對(duì)象替換集合內(nèi)已存在的記錄,如果不存在,則會(huì)插入obj對(duì)象。
這條命令比較簡(jiǎn)單,示例就省略了。
以上是mongodb更新數(shù)據(jù)的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
新聞標(biāo)題:mongodb更新數(shù)據(jù)的方法
標(biāo)題網(wǎng)址:http://www.chinadenli.net/article4/iijoie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供手機(jī)網(wǎng)站建設(shè)、面包屑導(dǎo)航、Google、云服務(wù)器、網(wǎng)站改版、品牌網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)