亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MongoDB > 正文

mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)

2020-03-14 12:58:13
字體:
來源:轉載
供稿:網友

對于文檔的更新除替換外,針對某個或多個文檔只需要部分更新可使用原子的更新修改器,能夠高效的進行文檔更新。更新修改器是中特殊的鍵,
用來指定復雜的操作,比如增加、刪除或者調整鍵,還可能是操作數組或者內嵌文檔。

1.$inc

這個修改器干什么使的呢?看看下面示例的具體操作后的結果即可知道。
示例文檔:{"uid":"201203","type":"1",size:10}

> db.b.insert({"uid":"201203","type":"1",size:10})> db.b.find(){ "_id" : ObjectId("5003b6135af21ff428dafbe6"), "uid" : "201203", "type" : "1","size" : 10 }> db.b.update({"uid" : "201203"},{"$inc":{"size" : 1}})> db.b.find(){ "_id" : ObjectId("5003b6135af21ff428dafbe6"), "uid" : "201203", "type" : "1","size" : 11 }> db.b.update({"uid" : "201203"},{"$inc":{"size" : 2}})> db.b.find(){ "_id" : ObjectId("5003b6135af21ff428dafbe6"), "uid" : "201203", "type" : "1","size" : 13 }> db.b.update({"uid" : "201203"},{"$inc":{"size" : -1}})> db.b.find(){ "_id" : ObjectId("5003b6135af21ff428dafbe6"), "uid" : "201203", "type" : "1","size" : 12 }

得出結論:修改器$inc可以對文檔的某個值為數字型(只能為滿足要求的數字)的鍵進行增減的操作。
(這里有個問題:上篇中說到更新默認只對滿足條件的記錄集中第一個文檔進行更新,那么使用$inc修改器之后,還是一樣嗎?)

2.$set

用來指定一個鍵并更新鍵值,若鍵不存在并創建。來看看下面的效果:

> db.a.findOne({"uid" : "20120002","type" : "3"}){ "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "sname" : "jk", "type" : "3", "uid" : "20120002" }--size鍵不存在的場合> db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"size":10}})> db.a.findOne({"uid" : "20120002","type" : "3"}){ "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "size" : 10, "sname" : "jk", "type" : "3", "uid" : "20120002" }--sname鍵存在的場合> db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"sname":"ssk"}})> db.a.find(){ "_id" : ObjectId("500216de81b954b6161a7d8f"), "desc" : "hello world2!", "num": 40, "size" : 10, "sname" : "ssk", "type" : "3", "uid" : "20120002" }{ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 50, "sname" : "jk", "type" : "1", "uid" : "20120002" }--可改變鍵的值類型> db.a.update({"uid" : "20120002","type" : "3"},{"$set":{"sname":["Java",".net","c++"]}})> db.a.findOne({"uid" : "20120002","type" : "3"}){  "_id" : ObjectId("500216de81b954b6161a7d8f"),  "desc" : "hello world2!",  "num" : 40,  "size" : 10,  "sname" : [    "java",    ".net",    "c++"  ],  "type" : "3",  "uid" : "20120002"}

對于內嵌的文檔,$set又是如何進行更新的內嵌的文檔的呢,請看下面的示例:
示例文檔:{"name":"toyota","type":"suv","size":{"height":10,"width":5,"length":15}}

> db.c.findOne({"name":"toyota"}){  "_id" : ObjectId("5003be465af21ff428dafbe7"),  "name" : "toyota",  "type" : "suv",  "size" : {    "height" : 10,    "width" : 5,    "length" : 15  }}> db.c.update({"name":"toyota"},{"$set":{"size.height":8}})> db.c.findOne({"name":"toyota"}){  "_id" : ObjectId("5003be465af21ff428dafbe7"),  "name" : "toyota",  "type" : "suv",  "size" : {    "height" : 8,    "width" : 5,    "length" : 15  }}> db.c.update({"name":"toyota"},{"$set":{"size.width":7}})> db.c.findOne({"name":"toyota"}){  "_id" : ObjectId("5003be465af21ff428dafbe7"),  "name" : "toyota",  "type" : "suv",  "size" : {    "height" : 8,    "width" : 7,    "length" : 15  }}

可見:對于內嵌文檔在使用$set更新時,使用"."連接的方式。

3.$unset

從字面就可以看出其意義,主要是用來刪除鍵。
示例操作效果如下:

> db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"sname":1}})> db.a.findOne({"uid" : "20120002","type" : "3"}){  "_id" : ObjectId("500216de81b954b6161a7d8f"),  "desc" : "hello world2!",  "num" : 40,  "size" : 10,  "type" : "3",  "uid" : "20120002"}> db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"num":0}})> db.a.findOne({"uid" : "20120002","type" : "3"}){  "_id" : ObjectId("500216de81b954b6161a7d8f"),  "desc" : "hello world2!",  "size" : 10,  "type" : "3",  "uid" : "20120002"}> db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"size":-1}})> db.a.findOne({"uid" : "20120002","type" : "3"}){  "_id" : ObjectId("500216de81b954b6161a7d8f"),  "desc" : "hello world2!",  "type" : "3",  "uid" : "20120002"}> db.a.update({"uid" : "20120002","type" : "3"},{"$unset":{"desc":"sssssss"}})> db.a.findOne({"uid" : "20120002","type" : "3"}){  "_id" : ObjectId("500216de81b954b6161a7d8f"),  "type" : "3",  "uid" : "20120002"}

得出結論:使用修改器$unset時,不論對目標鍵使用1、0、-1或者具體的字符串等都是可以刪除該目標鍵。

4.數組修改器--$push

示例操作效果如下:

> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "type" : "suv","size" : { "height" : 8, "width" : 7, "length" : 15 } }--先push一個當前文檔中不存在的鍵title> db.c.update({"name" : "toyota"},{$push:{"title":"t1"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1" ], "type" : "suv" } --再向title中push一個值> db.c.update({"name" : "toyota"},{$push:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2" ], "type" : "suv" }--再向title中push一個值> db.c.update({"name" : "toyota"},{$push:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }--再向一個已經存在的鍵值非數組類型的鍵push一個值> db.c.update({"name" : "toyota"},{$push:{"size.height":10}})Cannot apply $push/$pushAll modifier to non-array> db.c.update({"name" : "toyota"},{$push:{"name":"ddddddd"}})Cannot apply $push/$pushAll modifier to non-array

得出結論:$push--向文檔的某個數組類型的鍵添加一個數組元素,不過濾重復的數據。添加時鍵存在,要求鍵值類型必須是數組;鍵不存在,則創建數組類型的鍵。

5.數組修改器--$ne/$addToSet

主要給數組類型鍵值添加一個元素時,避免在數組中產生重復數據,$ne在有些情況是不通行的。

> db.c.update({"title" : {$ne:"t2"}},{$push:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }> db.c.update({"name" : "toyota"},{$addToSet:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2" ], "type" : "suv" }

6.數組修改器--$pop、$pull

$pop從數組的頭或者尾刪除數組中的元素,示例如下:

{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t3", "t4" ],"type" : "suv" }--從數組的尾部刪除 1> db.c.update({"name" : "toyota"},{$pop:{"title":1}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t3" ], "type" : "suv" }--從數組的頭部 -1> db.c.update({"name" : "toyota"},{$pop:{"title":-1}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t2", "t3" ], "type" : "suv" }--從數組的尾部刪除 0> db.c.update({"name" : "toyota"},{$pop:{"title":0}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t2" ], "type" : "suv" } $pull從數組中刪除滿足條件的元素,示例如下:{ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t2", "t2", "t3" ],"type" : "suv" } > db.c.update({"name" : "toyota"},{$pull:{"title":"t2"}})> db.c.find(){ "_id" : ObjectId("5003be465af21ff428dafbe7"), "name" : "toyota", "size" : { "height" : 8, "width" : 7, "length" : 15 }, "title" : [ "t1", "t3" ], "type" : "suv" }

7.數組的定位修改器

在需要對數組中的值進行操作的時候,可通過位置或者定位操作符("$").數組是0開始的,可以直接將下標作為鍵來選擇元素。
示例如下:

{"uid":"001",comments:[{"name":"t1","size":10},{"name":"t2","size":12}]}> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 10 }, { "name" : "t2", "size" : 12 } ] }> db.c.update({"uid":"001"},{$inc:{"comments.0.size":1}})> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 11 }, { "name" : "t2", "size" : 12 } ] }> db.c.update({"comments.name":"t1"},{$set:{"comments.$.size":1}})> db.c.find({"uid":"001"}){ "_id" : ObjectId("5003da405af21ff428dafbe8"), "uid" : "001", "comments" : [ {"name" : "t1", "size" : 1 }, { "name" : "t2", "size" : 12 } ] }--若為多個文檔滿足條件,則只更新第一個文檔。

8.upsert

upsert是一種特殊的更新。當沒有符合條件的文檔,就以這個條件和更新文檔為基礎創建一個新的文檔,如果找到匹配的文檔就正常的更新。
使用upsert,既可以避免競態問題,也可以減少代碼量(update的第三個參數就表示這個upsert,參數為true時)

> db.c.remove()> db.c.update({"size":11},{$inc:{"size":3}})> db.c.find()> db.c.update({"size":11},{$inc:{"size":3}},false)> db.c.find()> db.c.update({"size":11},{$inc:{"size":3}},true)> db.c.find(){ "_id" : ObjectId("5003ded6c28f67507a6df1de"), "size" : 14 }

9.save函數

1.可以在文檔不存在的時候插入,存在的時候更新,只有一個參數文檔。
2.要是文檔含有"_id",會調用upsert。否則,會調用插入。

> db.a.find(){ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 50, "sname" : "jk", "type" : "1", "uid" : "20120002" }> var o = db.a.findOne()> o.num = 5555> db.a.save(o)> db.a.find(){ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 55, "sname" : "jk", "type" : "1", "uid" : "20120002" }

 

 

注:相關教程知識閱讀請移步到MongoDB頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲xxxx在线| 欧美日本亚洲视频| 欧美尤物巨大精品爽| 国产精品av网站| 日韩精品在线私人| 欧美一区二区三区免费观看| 国产日韩欧美电影在线观看| 都市激情亚洲色图| 亚洲国产精品资源| 日韩欧美中文字幕在线播放| 亚洲人成在线观看网站高清| 国产视频综合在线| 欧美午夜丰满在线18影院| 日本三级久久久| 亚洲国产美女精品久久久久∴| 日韩男女性生活视频| 久久精品这里热有精品| 国产欧美va欧美va香蕉在线| 91精品视频在线免费观看| 成人激情在线播放| 欧美性20hd另类| 久久99国产综合精品女同| 成人国产精品久久久久久亚洲| 欧美在线中文字幕| 国产一区二区视频在线观看| 一本色道久久综合狠狠躁篇的优点| 91精品国产91久久久久久久久| 国产精品jizz在线观看麻豆| 55夜色66夜色国产精品视频| 久久综合免费视频| 亚洲成**性毛茸茸| 黑人巨大精品欧美一区二区三区| 欧美xxxx做受欧美| 欧美日韩黄色大片| 精品一区二区三区电影| 亚洲成色www8888| 北条麻妃一区二区在线观看| 91在线观看免费网站| 国产精品精品国产| 亚洲精品久久久久| 亚洲开心激情网| 欧美一性一乱一交一视频| 国产精品户外野外| 国内精品久久影院| 成人h猎奇视频网站| 国产精品欧美日韩| 国产精品久久久久久久电影| 国产日韩欧美视频| 日韩视频在线免费| 不卡伊人av在线播放| 日本最新高清不卡中文字幕| 国产成人在线一区二区| 欧美xxxx做受欧美| 国产精品国语对白| 亚洲香蕉伊综合在人在线视看| 精品久久久久久久久国产字幕| 欧美性猛交视频| 亚洲国产欧美日韩精品| 日本精品视频网站| 热久久99这里有精品| 国内精品视频一区| 欧美专区日韩视频| 亚洲国产精品女人久久久| 欧美中文在线观看| 国产精品无码专区在线观看| 国产精品久久久久久久久免费| 成人网欧美在线视频| 久久精品视频在线| 亚洲一区二区久久| 欧美区在线播放| 91精品国产91久久久久久吃药| 国产精品一区二区久久| 久久99国产精品自在自在app| 久久精品国产亚洲精品| 久久久久久久久爱| 欧美激情18p| 亚洲欧美日韩一区在线| 亚洲视频999| 日韩高清有码在线| 久久久久久999| 国产福利精品av综合导导航| 亚洲激情国产精品| 羞羞色国产精品| 欧美在线影院在线视频| 国产有码一区二区| 欧美精品少妇videofree| 国产欧美日韩中文字幕| 欧美大全免费观看电视剧大泉洋| 日韩精品有码在线观看| 亚洲一区二区三区久久| 亚洲视频999| 日韩欧美精品免费在线| 在线精品播放av| 色一区av在线| 欧美一级视频一区二区| 久久国产色av| 国产主播精品在线| 亚洲国产欧美在线成人app| 韩国19禁主播vip福利视频| 国产一区香蕉久久| 国产精品成人av性教育| 92看片淫黄大片欧美看国产片| 亚洲人免费视频| 国产成人在线亚洲欧美| 日韩视频免费中文字幕| 亚洲淫片在线视频| 国产精品91久久久久久| 国产日韩精品在线播放| 欧美性xxxx| 国产成人avxxxxx在线看| 久久久久久亚洲精品| 久久6免费高清热精品| 久久精品99无色码中文字幕| 国产精品成人观看视频国产奇米| 中文字幕亚洲欧美日韩在线不卡| www.久久色.com| 亚洲欧美日韩一区二区在线| 亚洲第一免费播放区| 成人国产精品久久久| 精品美女国产在线| 国产精彩精品视频| 亚洲精品一区中文| 色婷婷综合久久久久中文字幕1| 亚洲精品在线观看www| 欧美亚洲日本网站| 国产99久久精品一区二区 夜夜躁日日躁| 欧美日韩成人网| 伊人久久久久久久久久久| 综合av色偷偷网| 国产精品男人的天堂| www高清在线视频日韩欧美| 亚洲男人的天堂在线| 日韩av在线免播放器| 国产成人小视频在线观看| 2025国产精品视频| 97超级碰碰人国产在线观看| 高清欧美性猛交xxxx黑人猛交| 91精品久久久久久久久久| 久久99热精品这里久久精品| 久久69精品久久久久久久电影好| 久久免费精品日本久久中文字幕| 亚洲网站在线看| 91美女高潮出水| 久久精品99久久香蕉国产色戒| 精品人伦一区二区三区蜜桃网站| 欧美怡春院一区二区三区| 亚洲欧美制服综合另类| 91高潮精品免费porn| 欧美一区二区大胆人体摄影专业网站| 欧美另类在线观看| 91久久久久久久久久| 色99之美女主播在线视频| 国产日韩中文在线| 欧美黑人极品猛少妇色xxxxx| 色综合久久中文字幕综合网小说| 欧美日韩午夜激情| 国产精品69久久久久| 色综合久久久888| 91久久嫩草影院一区二区| 国内精品视频一区| 亚洲xxxx3d| 欧洲成人免费aa| 精品亚洲va在线va天堂资源站| 亚洲女性裸体视频|