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

主頁(yè) > 知識(shí)庫(kù) > mongoDB中CRUD的深入講解

mongoDB中CRUD的深入講解

熱門標(biāo)簽:呼和浩特外呼系統(tǒng)原理是什么 crm外呼系統(tǒng)聯(lián)系方式 長(zhǎng)沙電銷外呼防封卡是什么 小裙科技電銷機(jī)器人怎樣 智能外呼系統(tǒng)官網(wǎng) 內(nèi)蒙古營(yíng)銷智能外呼系統(tǒng)哪個(gè)好 外呼線路資源屬于電信業(yè)務(wù)嗎 河南電話外呼系統(tǒng)招商 青白江400企業(yè)電話申請(qǐng)

前言

今天開(kāi)始接觸非關(guān)系型數(shù)據(jù)庫(kù)的mongoDB,現(xiàn)在將自己做的筆記發(fā)出來(lái),供大家參考,也便于自己以后忘記了可以查看。

首先,mongoDB,是一種數(shù)據(jù)庫(kù),但是又區(qū)別與mysql,sqlserver、orcle等關(guān)系數(shù)據(jù)庫(kù),在優(yōu)勢(shì)上面也略高一籌;至于為什么會(huì)這么說(shuō)呢?很簡(jiǎn)單,我們來(lái)舉兩個(gè)例子:

1.在存儲(chǔ)上面,非關(guān)系型數(shù)據(jù)庫(kù)可以更大規(guī)模的存儲(chǔ),打個(gè)比方,F(xiàn)acebook用的數(shù)據(jù)庫(kù)就是非關(guān)系型數(shù)據(jù)庫(kù)。

2.運(yùn)用起來(lái)更加流暢也是這個(gè)數(shù)據(jù)庫(kù)的優(yōu)點(diǎn),將分布式的特點(diǎn)發(fā)揮到極致。

當(dāng)我查看官方文檔的時(shí)候,簡(jiǎn)直要人命,光是一個(gè)插入方法都講了好幾條,腦袋都大了,現(xiàn)在我總結(jié)一下每一插入方法的特性

db.collection.insert()

db.collection.insert() 向集合插入一個(gè)或多個(gè)文檔.要想插入一個(gè)文檔,傳遞一個(gè)文檔給該方法;要想插入多個(gè)文檔,就可以采用該方法。

例如

db.users.insert(
   [
    { name: "bob", age: 42, status: "A", },
    { name: "ahn", age: 22, status: "A", },
    { name: "xi", age: 34, status: "D", }
   ]
   )

如果插入成功就會(huì)返回

WriteResult({ "nInserted" : 3 })

如果異常情況,那么就會(huì)返回如下咯:

WriteResult({
   "nInserted" : 3,
   "writeConcernError" : {
    "code" : 64,
    "errmsg" : "waiting for replication timed out at shard-a"
   }
   })

當(dāng)我們想插入一條數(shù)據(jù)的時(shí)候,采用insert的方法據(jù)比較浪費(fèi)內(nèi)存,這個(gè)時(shí)候,我們久采用插入單個(gè)的語(yǔ)法db.collection.insertOne() 向集合插入 單個(gè) 文檔 document 舉個(gè)小列子來(lái)說(shuō)明一下。

db.users.insertOne(
   {
    name: "sue",
    age: 19,
    status: "P"
   }
   )

有了單個(gè),就肯定會(huì)有多個(gè),那么多個(gè)又是怎么樣的呢?語(yǔ)法都很類似,db.collection.insertMany()這個(gè)語(yǔ)法跟上面沒(méi)有區(qū)別嘛,對(duì)不對(duì),當(dāng)然是錯(cuò)的,你想,如果添加的數(shù)據(jù)是數(shù)組里面嵌套數(shù)組,前面兩個(gè)的方法的性能就大打折扣了,影響數(shù)據(jù)庫(kù)的性能。廢話少說(shuō),列子走一波:

db.users.insertMany(
   [
    {
    _id: 1,
    name: "sue",
    age: 19,
    type: 1,
    status: "P",
    favorites: { artist: "Picasso", food: "pizza" },
    finished: [ 17, 3 ],
    badges: [ "blue", "black" ],
    points: [
     { points: 85, bonus: 20 },
     { points: 85, bonus: 10 }
    ]
    },
    {
    _id: 2,
    name: "bob",
    age: 42,
    type: 1,
    status: "A",
    favorites: { artist: "Miro", food: "meringue" },
    finished: [ 11, 25 ],
    badges: [ "green" ],
    points: [
     { points: 85, bonus: 20 },
     { points: 64, bonus: 12 }
    ]
    },
    {
    _id: 3,
    name: "ahn",
    age: 22,
    type: 2,
    status: "A",
    favorites: { artist: "Cassatt", food: "cake" },
    finished: [ 6 ],
    badges: [ "blue", "Picasso" ],
    points: [
     { points: 81, bonus: 8 },
     { points: 55, bonus: 20 }
    ]
    },
    {
    _id: 4,
    name: "xi",
    age: 34,
    type: 2,
    status: "D",
    favorites: { artist: "Chagall", food: "chocolate" },
    finished: [ 5, 11 ],
    badges: [ "Picasso", "black" ],
    points: [
     { points: 53, bonus: 15 },
     { points: 51, bonus: 15 }
    ]
    },
    {
    _id: 5,
    name: "xyz",
    age: 23,
    type: 2,
    status: "D",
    favorites: { artist: "Noguchi", food: "nougat" },
    finished: [ 14, 6 ],
    badges: [ "orange" ],
    points: [
     { points: 71, bonus: 20 }
    ]
    },
    {
    _id: 6,
    name: "abc",
    age: 43,
    type: 1,
    status: "A",
    favorites: { food: "pizza", artist: "Picasso" },
    finished: [ 18, 12 ],
    badges: [ "black", "blue" ],
    points: [
     { points: 78, bonus: 8 },
     { points: 57, bonus: 7 }
    ]
    }
   ]
   )

注意:insertOne()、insertMany()是3.2版本的語(yǔ)法。

既然增了,就得查找,對(duì)吧,查找里面呢也有很多小東西,有許多自己自定義查詢。

1、查詢?nèi)?/p>

db.users.find( {} ) 等價(jià)于db.users.find()

2、指定等于條件

一個(gè) query filter document 可以使用 field>:value> 表達(dá)式指定等于條件以選擇所有包含 field> 字段并且等于特定 value> 的所有文檔:

下面的示例從 user 集合中檢索 status 字段值為 “P” 或者 “D” 的所有文檔:

db.users.find( { status: { $in: [ "P", "D" ] } } )

3、指定 AND 條件

復(fù)合查詢可以在集合文檔的多個(gè)字段上指定條件。隱含地,一個(gè)邏輯的 AND 連接詞會(huì)連接復(fù)合查詢的子句,使得查詢選出集合中匹配所有條件的文檔。

下面的示例在 users 集合中檢索 status 等于 "A"``**并且** ``age 小于 ($lt) 30是所有文檔:

db.users.find( { status: "A", age: { $lt: 30 } } )

4、指定 OR 條件

通過(guò)使用 $or 操作符,你可以指定一個(gè)使用邏輯 OR 連接詞連接各子句的復(fù)合查詢選擇集合中匹配至少一個(gè)條件的文檔。

下面的示例在 users 集合中檢索 status` 等于 "A"**或者**age 小于 ($lt) 30 所有文檔:

db.users.find(
      {
        $or: [ { status: "A" }, { age: { $lt: 30 } } ]
      }
      )

5、指定 AND 和 OR 條件(可以更加精確的查詢)

在下面的示例中,復(fù)合查詢文檔選擇集合中status`` 等于 "A" 并且 要么 age 小于 ($lt) 30 要么 type 等于 1 的所有文檔:

db.users.find(
      {
        status: "A",
        $or: [ { age: { $lt: 30 } }, { type: 1 } ]
      }
      )

6、嵌入文檔上的精確匹配

使用{ field>: value> }并且 “” 為要匹配文檔的查詢文檔,來(lái)指定匹配整個(gè)內(nèi)嵌文檔的完全相等條件.(要使)相等條件匹配上內(nèi)嵌文檔需要指定 包括字段順序的 精確 匹配。

在下面的例子中,查詢匹配所有 favorites 字段是以該種順序只包含 等于 "Picasso"``的 ``artist 和等于 "pizza" 的 food 字段的內(nèi)嵌文檔:

db.users.find( { favorites: { artist: "Picasso", food: "pizza" } } )

7、嵌入文檔中字段上的等于匹配

在下面的例子中,查詢使用 dot notation 匹配所有 favorites 字段是包含等于 "Picasso" 的字段 ``artist``(可能還包含其他字段) 的內(nèi)嵌文檔:

db.users.find( { "favorites.artist": "Picasso" } )

8、數(shù)組上的查詢

采用一個(gè)參數(shù): $elemMatch (該參數(shù)是值精確的數(shù)組)

下面的例子查詢 finished 數(shù)組至少包含一個(gè)大于 ($gt) 15 并且小于 ($lt) 20 的元素的文檔:

db.users.find( { finished: { $elemMatch: { $gt: 15, $lt: 20 } } } )

9、嵌入文檔數(shù)組

使用數(shù)組索引匹配嵌入文檔中的字段

在下面的例子中,查詢使用 the dot notation 匹配所有 dadges 是第一個(gè)元素為”black” 的數(shù)組的文檔:

db.users.find( { 'points.0.points': { $lte: 55 } } )

10、不指定數(shù)組索引匹配字段

如果你不知道文檔在數(shù)組中的索引位置,用點(diǎn)號(hào) (.) 將包含數(shù)組的字段的名字和內(nèi)嵌文檔的字段的名字連起來(lái)。

下面的例子選擇出所有 points``數(shù)組中至少有一個(gè)嵌入文檔包含值小于或等于 ``55 的字段 points 的文檔:

db.users.find( { 'points.points': { $lte: 55 } } )

11、指定數(shù)組文檔的多個(gè)查詢條件

單個(gè)元素滿足查詢條件

使用 $elemMatch 操作符為數(shù)組元素指定復(fù)合條件,以查詢數(shù)組中至少一個(gè)元素滿足所有指定條件的文檔。

下面的例子查詢 points 數(shù)組有至少一個(gè)包含 points 小于等于 70 并且字段 bonus 等于 20 的內(nèi)嵌文檔的文檔:

db.users.find( { points: { $elemMatch: { points: { $lte: 70 }, bonus: 20 } } }

12、元素組合滿足查詢條件

下面的例子查詢了 points 數(shù)組包含了以某種組合滿足查詢條件的元素的文檔;例如,一個(gè)元素滿足 points 小于等于 70 的條件并且有另一個(gè)元素滿足 bonus 等于 20 的條件,或者一個(gè)元素同時(shí)滿足兩個(gè)條件:

db.users.find( { "points.points": { $lte: 70 }, "points.bonus": 20 } )

接下來(lái)就是更新咯,老樣子跟插入方法差不多,更新就可以看做是插入的一種。

來(lái)一段官方文檔的話:

如果 db.collection.update() db.collection.updateOne() db.collection.updateMany() 或者 db.collection.replaceOne() 包含 upsert : true 并且 沒(méi)有文檔匹配指定的過(guò)濾器,那么此操作會(huì)創(chuàng)建一個(gè)新文檔并插入它。如果有匹配的文檔,那么此操作修改或替換匹配的單個(gè)或多個(gè)文檔。

這個(gè)解釋在我認(rèn)為就是在沒(méi)有該數(shù)據(jù)的時(shí)候就會(huì)創(chuàng)建相應(yīng)的數(shù)據(jù),畢竟它是插入的一種特殊方法。

1、db.collection.updateOne():修改單條數(shù)據(jù)

下面的例子對(duì) users 集合使用 db.collection.updateOne() 方法來(lái)更新第一個(gè) 根據(jù) 過(guò)濾條件favorites.artist 等于 “Picasso” 匹配到的文檔更新操作:

使用 $set 操作符更新 favorites.food 字段的值為 “pie” 并更新 type 字段的值為 3,

db.users.updateOne(
      { "favorites.artist": "Picasso" },
      {
        $set: { "favorites.food": "pie", type: 3 },
        
      }
      )

2、db.collection.update()的用法和db.collection.updateOne()類似,為了區(qū)別一下,我們采用了 { multi: true }這個(gè)參數(shù),這樣會(huì)在你修改之后的數(shù)據(jù)中有這個(gè)參數(shù),表示修改完成。

db.users.update(
      { "favorites.artist": "Pisanello" },
      {
        $set: { "favorites.food": "pizza", type: 0, }
      },
      { multi: true }
      )

3、 db.collection.updateMany(),這個(gè)會(huì)不會(huì)認(rèn)為是修改很多,當(dāng)然可以這么理解,但是我更喜歡把他理解成修改多個(gè)參數(shù)。

下面這個(gè)舉例就是為了大家看的明白采用了{(lán) upsert: true },它可以清晰的返回你修改后的值

 db.inspectors.updateMany(
        { "Sector" : { $gt : 4 }, "inspector" : "R. Coltrane" },
        { $set: { "Patrolling" : false } },
        { upsert: true }
      );

4、修改還有一個(gè)就是文檔替換db.collection.replaceOne
下面的例子對(duì) users 集合使用 db.collection.replaceOne() 方法將通過(guò)過(guò)濾條件 name 等于 "sue" 匹配到的 **第一個(gè)** 文檔替換為新文檔:

db.users.replaceOne(
      { name: "abc" },
      { name: "amy", age: 34, type: 2, status: "P", favorites: { "artist": "Dali", food: "donuts" } }
      )

走著,擼刪除了:

1、刪除所有文檔db.collection.remove()

這個(gè)方法就干脆了,就相當(dāng)于sql中的刪除表結(jié)構(gòu)的delete()

db.users.remove({})

作為另一種選擇如下例子使用 db.collection.remove() 從 users 集合中刪除所有 status 字段等于 “A” 的文檔:

db.users.remove( { status : "P" } )

2、僅刪除一個(gè)滿足條件的文檔db.collection.deleteOne()

如下例子使用 db.collection.deleteOne() 刪除 第一個(gè) status 字段等于 “A” 的文檔:

db.users.deleteOne( { status: "D" } )

3、刪除集合中所有文檔db.collection.deleteMany()

如下的例子使用 db.collection.deleteMany() 方法從 users 集合中刪除了 所有 文檔:

db.users.deleteMany({})

以上是通過(guò)兩天學(xué)習(xí)官方文達(dá)能的總結(jié),下面配上官方文檔的地址表示感謝。
https://docs.mongodb.com/manual/reference/method/js-collection/

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

您可能感興趣的文章:
  • MongoDB CRUD操作中的插入實(shí)例教程
  • Springboot整合MongoDB進(jìn)行CRUD操作的兩種方式(實(shí)例代碼詳解)
  • MongoDB的基本操作實(shí)例詳解【服務(wù)端啟動(dòng),客戶端連接,CRUD操作】
  • MongoDB 常用的crud操作語(yǔ)句

標(biāo)簽:池州 白山 楚雄 黃石 菏澤 呼倫貝爾 安順 舟山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mongoDB中CRUD的深入講解》,本文關(guān)鍵詞  mongoDB,中,CRUD,的,深入,講解,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mongoDB中CRUD的深入講解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于mongoDB中CRUD的深入講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产iv一区二区三区| 久久精品国产亚洲aⅴ| 久久欧美一区二区| 26uuu精品一区二区| 欧美精品一区二区三区在线| 欧美不卡在线视频| 久久久精品免费免费| 337p粉嫩大胆噜噜噜噜噜91av| 激情综合五月天| 成人中文字幕合集| 在线观看成人小视频| 日韩三级电影网址| 亚洲国产精品v| 亚洲3atv精品一区二区三区| 奇米影视一区二区三区小说| 国产一区二区三区蝌蚪| 日本道在线观看一区二区| 日韩一级黄色大片| 国产欧美一区二区精品忘忧草| 国产精品亲子伦对白| 亚洲一区二区三区视频在线播放 | 亚洲午夜在线观看视频在线| 青青草91视频| 色婷婷av久久久久久久| 久久午夜老司机| 舔着乳尖日韩一区| 91免费观看国产| 久久久精品综合| 麻豆精品在线观看| 欧美日韩视频一区二区| 日本不卡一区二区三区| 99精品欧美一区| 国产精品久久久久精k8| 色哟哟国产精品| 国产精品日产欧美久久久久| 久久成人av少妇免费| 精品国产亚洲在线| 免费一区二区视频| 精品欧美黑人一区二区三区| 日本不卡中文字幕| 日韩欧美中文字幕制服| 免费在线观看成人| 欧美刺激午夜性久久久久久久| 青青草伊人久久| 国产精品狼人久久影院观看方式| 久久99热狠狠色一区二区| 国产亚洲精品aa午夜观看| 国产精品资源在线看| 国产精品久久久久久久久动漫 | 国产精品婷婷午夜在线观看| 成人综合在线视频| 中文字幕一区免费在线观看| www.亚洲在线| 午夜精品久久久久影视| 精品免费国产二区三区| 日韩视频一区二区在线观看| 国内精品第一页| 一区二区三区 在线观看视频| 在线精品视频免费观看| 精品一区二区综合| 亚洲综合av网| 欧美激情自拍偷拍| 日韩午夜在线观看| 99久久久久久| 懂色av一区二区夜夜嗨| 麻豆精品视频在线| 亚洲电影视频在线| 中文字幕一区二区不卡| 26uuu久久天堂性欧美| 欧美一级淫片007| 欧美日韩亚洲高清一区二区| 成人激情黄色小说| 国内国产精品久久| 国产一区二区免费视频| 视频一区视频二区中文字幕| 亚洲欧美视频在线观看视频| 国产亚洲1区2区3区| ww亚洲ww在线观看国产| 亚洲精品一区二区三区99| 日韩亚洲欧美高清| 91精品国产综合久久久久久漫画 | 中文字幕av资源一区| 国产精品午夜春色av| 国产三级久久久| 中文字幕不卡的av| 亚洲日本青草视频在线怡红院| 国产精品久久久久久久久免费丝袜| 国产亚洲一区字幕| 国产精品久久久久一区二区三区| 国产日本一区二区| 国产精品国产三级国产专播品爱网| 国产欧美日韩不卡| 亚洲精品日韩综合观看成人91| 自拍偷在线精品自拍偷无码专区| 久久狠狠亚洲综合| 国产精品一区专区| 99re成人精品视频| 99精品久久免费看蜜臀剧情介绍| 欧美午夜寂寞影院| 91精品欧美综合在线观看最新| 欧美tk丨vk视频| 亚洲精品美腿丝袜| 韩国视频一区二区| 欧美色男人天堂| 中文字幕欧美三区| 日日夜夜免费精品| 色偷偷一区二区三区| 在线播放亚洲一区| 一二三区精品福利视频| 九九精品视频在线看| 欧美综合在线视频| 欧美激情一区三区| 久久丁香综合五月国产三级网站| 99精品久久久久久| 久久精品视频免费观看| 日韩vs国产vs欧美| av在线不卡观看免费观看| 亚洲一区二区三区四区在线观看 | 日韩欧美色综合| 亚洲不卡在线观看| 欧美色综合久久| 一区二区三区在线观看欧美| 丰满少妇在线播放bd日韩电影| 91麻豆精品国产无毒不卡在线观看| 中文字幕在线不卡一区| 国产mv日韩mv欧美| 国产精品传媒在线| 99re免费视频精品全部| 亚洲欧美日韩在线不卡| 91首页免费视频| 亚洲成人av电影在线| 欧美日韩一区二区在线视频| 亚洲成av人片在www色猫咪| 欧美丰满嫩嫩电影| 男女性色大片免费观看一区二区 | 欧美一级午夜免费电影| 久久超级碰视频| 国产精品午夜久久| 欧美在线一二三| 麻豆精品一二三| 国产精品欧美一区喷水| 在线看一区二区| 美女视频网站黄色亚洲| 国产欧美一区二区精品性色| 不卡电影免费在线播放一区| 亚洲美女一区二区三区| 日韩一区二区三区在线观看| 国模一区二区三区白浆| 亚洲色图欧洲色图| 91麻豆精品国产91久久久久久| 国产一区999| 亚洲高清视频中文字幕| 国产日韩欧美a| 777久久久精品| 91尤物视频在线观看| 国产在线国偷精品免费看| 尤物视频一区二区| 欧美精品一区二区在线观看| 欧美日韩国产美女| 成人av影院在线| 国产精品一区二区你懂的| 天天免费综合色| 亚洲国产欧美一区二区三区丁香婷| 国产女主播视频一区二区| 日韩午夜激情免费电影| 91国模大尺度私拍在线视频| 夫妻av一区二区| 丁香桃色午夜亚洲一区二区三区| 日本少妇一区二区| 天天综合色天天| 日韩av一区二区在线影视| 亚洲va欧美va国产va天堂影院| 亚洲成人三级小说| 亚洲成av人**亚洲成av**| 亚洲国产精品久久人人爱| 一区二区三区在线观看动漫| 亚洲精选视频在线| 亚洲资源中文字幕| 美女网站在线免费欧美精品| 国产精品资源在线看| 99精品视频一区二区三区| 色88888久久久久久影院野外 | 久久久噜噜噜久久人人看| 久久久无码精品亚洲日韩按摩| 日本一区二区三区电影| 亚洲一卡二卡三卡四卡| 狠狠色丁香婷婷综合| 福利一区福利二区| 91久久人澡人人添人人爽欧美| 欧美电影在线免费观看| 久久蜜臀精品av| 一区二区三区精品| 国产成人在线色| 日韩一区二区电影网| 一区二区中文视频| 精品亚洲国产成人av制服丝袜| 不卡的电影网站| 2020日本不卡一区二区视频| 亚洲伊人色欲综合网| www..com久久爱|