婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)

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

熱門標簽:電銷機器人是什么軟件 杭州人工電銷機器人價格 云南外呼系統 老虎洗衣店地圖標注 呼和浩特電銷外呼系統加盟 蘋果汽車租賃店地圖標注 濟南電銷機器人加盟公司 怎么投訴地圖標注 廣州長安公司怎樣申請400電話

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

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 = 55
55
> db.a.save(o)
> db.a.find()
{ "_id" : ObjectId("50026affdeb4fa8d154f8572"), "desc" : "hello world1!", "num": 55,
 "sname" : "jk", "type" : "1", "uid" : "20120002" }

標簽:廈門 興安盟 雞西 遼陽 泰安 玉林 無錫 自貢

巨人網絡通訊聲明:本文標題《mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)》,本文關鍵詞  mongodb,修改器,inc,set,unset,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)》相關的同類信息!
  • 本頁收集關于mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品剧情在线观看| 欧美韩国日本不卡| 午夜欧美2019年伦理| 欧美日韩一区二区三区高清| 国产欧美一区二区三区鸳鸯浴| 成人免费看片app下载| 亚洲精品成人精品456| 日韩女优毛片在线| 在线精品视频免费播放| 麻豆国产一区二区| 中文字幕一区av| 91精品国产色综合久久不卡电影 | 经典三级在线一区| 欧美国产精品中文字幕| 91久久免费观看| 久色婷婷小香蕉久久| 亚洲欧美影音先锋| 精品久久久久99| 欧美亚日韩国产aⅴ精品中极品| 国内精品国产成人国产三级粉色| 日韩毛片一二三区| 久久久精品免费免费| 3d动漫精品啪啪一区二区竹菊| 成人妖精视频yjsp地址| 韩国女主播一区二区三区| 亚洲大片精品永久免费| 亚洲美女一区二区三区| 国产精品麻豆网站| 国产三级欧美三级日产三级99| 欧美一区日韩一区| 91精品国产91久久综合桃花| 97se亚洲国产综合自在线| 国产99久久久国产精品潘金网站| 国产乱码字幕精品高清av| 日韩黄色免费电影| 免费人成在线不卡| 久久国产视频网| 韩国精品在线观看| 国产福利一区二区三区| 国产精品99久久久久久久女警| 日本不卡视频一二三区| 青青草国产成人av片免费| 天堂资源在线中文精品| 免费成人美女在线观看.| 蜜桃视频在线观看一区二区| 日本网站在线观看一区二区三区| 三级欧美韩日大片在线看| 免费日韩伦理电影| 国产乱理伦片在线观看夜一区| 国产成人免费xxxxxxxx| 99久久夜色精品国产网站| 欧美视频一区二| 欧美va亚洲va在线观看蝴蝶网| 国产亚洲综合在线| 一区二区三区在线播放| 美女精品自拍一二三四| 99久精品国产| 日韩一二三区不卡| 国产激情视频一区二区在线观看| 国产精品久久久久久久久图文区| 国产午夜精品久久久久久久| 久久久精品日韩欧美| 国产精品拍天天在线| 依依成人精品视频| 秋霞成人午夜伦在线观看| 久久爱另类一区二区小说| 成人污视频在线观看| 欧美综合欧美视频| 26uuu精品一区二区三区四区在线| 一区在线中文字幕| 久久精品国产亚洲高清剧情介绍 | 欧美日韩一区二区在线视频| 日韩精品一区二区三区swag| 亚洲女同ⅹxx女同tv| 精品一区二区三区视频| av网站一区二区三区| 538prom精品视频线放| 国产精品私人影院| 国模少妇一区二区三区| 3d成人动漫网站| 亚洲国产精品欧美一二99| 国产99精品在线观看| 欧美一区二区精品| 亚洲国产日韩在线一区模特| 国产精品中文字幕一区二区三区| 欧美日韩中字一区| 亚洲成a人片综合在线| 91蜜桃网址入口| 亚洲三级久久久| 国产成人精品免费网站| 久久亚洲精品小早川怜子| 久久超级碰视频| 久久亚区不卡日本| 国精品**一区二区三区在线蜜桃| 4438x成人网最大色成网站| 亚洲成人av中文| 欧美三级一区二区| 国产成人亚洲综合a∨婷婷图片| 欧美日韩国产另类一区| 一区二区免费看| 欧美福利电影网| 日本伊人色综合网| 精品国产乱码久久久久久久| 国产麻豆视频一区二区| 国产精品免费观看视频| 91久久精品一区二区三| 亚洲大片精品永久免费| 精品国产三级电影在线观看| 国产成人自拍在线| 欧美极品少妇xxxxⅹ高跟鞋| 国产精品一区二区不卡| 中文字幕在线不卡| 色综合天天综合网国产成人综合天| 亚洲女子a中天字幕| 欧美精品 国产精品| 国产麻豆精品视频| 亚洲精品高清视频在线观看| 欧美www视频| 一本大道久久精品懂色aⅴ| 亚洲妇女屁股眼交7| 精品久久久久一区| 99精品久久只有精品| 一区二区三区中文在线| 欧美一卡二卡三卡四卡| 国产精品一区二区男女羞羞无遮挡| 国产性做久久久久久| 色悠久久久久综合欧美99| 婷婷夜色潮精品综合在线| 日韩久久一区二区| 欧美图片一区二区三区| 色噜噜狠狠一区二区三区果冻| 尤物av一区二区| 一二三四社区欧美黄| 日韩欧美第一区| 国产精品妹子av| 日韩欧美成人一区二区| 91麻豆精品国产91久久久使用方法| 色诱视频网站一区| 91免费看视频| 色婷婷av一区| 日本韩国欧美在线| 91女人视频在线观看| 99久久精品情趣| 国产xxx精品视频大全| 夜夜嗨av一区二区三区中文字幕| 亚洲欧洲av在线| 亚洲三级在线观看| 一区二区免费在线播放| 亚洲国产wwwccc36天堂| 一区二区三区**美女毛片| 夜夜夜精品看看| 日韩成人一级片| 麻豆精品视频在线观看免费| 韩国v欧美v日本v亚洲v| 成人激情图片网| 在线观看91精品国产入口| 色菇凉天天综合网| 欧美日韩一区二区在线视频| 欧美日韩国产高清一区| 欧美一级搡bbbb搡bbbb| 国产日韩欧美精品在线| 亚洲欧美一区二区三区极速播放| 亚洲.国产.中文慕字在线| 精品一区二区免费| 99精品视频一区二区三区| 欧美日韩日本视频| 欧美精品一区二区三区蜜臀| 国产精品女同一区二区三区| 亚洲综合小说图片| 久久99精品国产| 91日韩一区二区三区| 欧美成人a∨高清免费观看| 国产精品乱子久久久久| 日韩高清在线电影| 91在线观看一区二区| 欧美一区二区在线免费播放| 国产精品久久久久久亚洲毛片 | 国产高清久久久久| 欧美日韩一级二级| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美日本乱大交xxxxx| 欧美性一二三区| 国产精品五月天| 久久夜色精品国产欧美乱极品| 国产日产欧美一区二区三区| 中文字幕欧美日本乱码一线二线| 亚洲国产精品尤物yw在线观看| 久久99精品国产麻豆婷婷洗澡| 91精彩视频在线观看| 欧美变态凌虐bdsm| 亚洲成在人线在线播放| 国产精品自拍一区| 欧美一级二级三级蜜桃| 亚洲成人www| 欧美日产国产精品| 亚洲午夜精品17c| 欧美电影一区二区| 日产国产欧美视频一区精品| 欧美日韩电影一区| 亚洲一区二区三区免费视频|