這篇文章主要介紹MongoDB更新數據的方法,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
成都創新互聯專注于扎賚諾爾網站建設服務及定制,我們擁有豐富的企業做網站經驗。 熱誠為您提供扎賚諾爾營銷型網站建設,扎賚諾爾網站制作、扎賚諾爾網頁設計、扎賚諾爾網站官網定制、小程序開發服務,打造扎賚諾爾網絡公司原創品牌,更為您提供扎賚諾爾網站排名全網營銷落地服務。
Mongodb更新有兩個命令:update、save。
1.1update命令
update命令格式:
db.collection.update(criteria,objNew,upsert,multi)
參數說明:
criteria:查詢條件。
objNew:update對象和一些更新操作符。
upsert:如果不存在update的記錄,是否插入objNew這個新的文檔,true為插入,默認為false,不插入。
multi:默認是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的值,所以全部默認為false,由結果可以看出,只修改了第一條符合條件的記錄。
示例2:把count大于20的class name修改為c4,設置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,所以對兩條符合條件的記錄都進行了更新。
示例3: 把count大于50的class name修改為c5,設置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代表需要更新的對象,如果集合內部已經存在一個和obj相同的"_id"的記錄,Mongodb會把obj對象替換集合內已存在的記錄,如果不存在,則會插入obj對象。
這條命令比較簡單,示例就省略了。
以上是mongodb更新數據的方法的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注創新互聯行業資訊頻道!
新聞標題:mongodb更新數據的方法
標題網址:http://vcdvsql.cn/article4/iijoie.html
成都網站建設公司_創新互聯,為您提供手機網站建設、面包屑導航、Google、云服務器、網站改版、品牌網站設計
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯