您好,登錄后才能下訂單哦!
這篇文章主要介紹mongodb更新數(shù)據(jù)的方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
Mongodb更新有兩個命令:update、save。
1.1update命令
update命令格式:
db.collection.update(criteria,objNew,upsert,multi)
參數(shù)說明:
criteria:查詢條件。
objNew:update對象和一些更新操作符。
upsert:如果不存在update的記錄,是否插入objNew這個新的文檔,true為插入,默認(rèn)為false,不插入。
multi:默認(rèn)是false,只更新找到的第一條記錄。如果為true,把按條件查詢出來的記錄全部更新。
示例:
> 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 } >
由于沒有指定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,所以對兩條符合條件的記錄都進(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" } >
在集合中沒有count大于50的記錄,但是由于指定了upsert為true,如果找不到則會插入一條新記錄。
1.2save命令
Mongodb另一個更新命令是save,格式如下:
db.collection.save(obj)
obj代表需要更新的對象,如果集合內(nèi)部已經(jīng)存在一個和obj相同的"_id"的記錄,Mongodb會把obj對象替換集合內(nèi)已存在的記錄,如果不存在,則會插入obj對象。
這條命令比較簡單,示例就省略了。
以上是mongodb更新數(shù)據(jù)的方法的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。