人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

使用MongoDB操作文檔

發(fā)布日期:2022-07-15 19:07 | 文章來(lái)源:源碼之家

本篇文章中將講解如何使用MongoDB操作文檔。

文檔的數(shù)據(jù)結(jié)構(gòu)和JSON基本一致,所有存儲(chǔ)在集合中的數(shù)據(jù)都是BSON格式。BSON是一種類似json格式的一種二進(jìn)制形式的存儲(chǔ)格式,簡(jiǎn)稱Binary JSON。

一、插入文檔

MongoDB使用insert()或save()方法向集合中插入文檔,語(yǔ)法如下:

db.COLLECTION_NAME.insert(document)

例如:以下文檔可以存儲(chǔ)在MongoDB的test數(shù)據(jù)庫(kù)的MongoDBTest集合中:

{"title" : "MongoDB", "description" : "mongoDB是一個(gè)NoSql數(shù)據(jù)庫(kù)", "tags" : "NoSql" }

1、使用insert()方法插入文檔

在上面的例子中,MongoDBTest是我們的集合名,如果該集合不在該數(shù)據(jù)庫(kù)中,MongoDB會(huì)自動(dòng)創(chuàng)建該集合并插入文檔。doc是定義的變量,可以以變量的形式插入集合。

查看已經(jīng)插入的文檔:

> db.MongoDBTest.insert(doc)
WriteResult({ "nInserted" : 1 })
> db.MongoDBTest.find()
{ "_id" : ObjectId("5a6f13e72d0b37669c5d2a78"), "title" : "MongoDB", "description" : "mongoDB是一個(gè)NoSql數(shù)據(jù)庫(kù)", "tags" : "NoSql" }
>

2、使用save()方法插入文檔

插入文檔也可以使用save()方法。如果不知道_id字段save()方法類似于insert()方法。如果指定_id字段,則會(huì)更新該_id的數(shù)據(jù)。

下面的例子表示使用save()命令更新數(shù)據(jù):

二、查詢文檔

MongoDB查詢文檔使用find()方法。

find()方法以非結(jié)構(gòu)化的方式來(lái)顯示所有文檔。

1、語(yǔ)法

MongoDB查詢數(shù)據(jù)的語(yǔ)法格式如下:

db.collection.find(query,projection)

參數(shù)說(shuō)明:

  • query:可選參數(shù),使用查詢操作符指定查詢條件。
  • projection:可選參數(shù),使用投影操作符指定返回的鍵。如果查詢時(shí)要返回文檔中所有鍵值,只需省略該參數(shù)即可(默認(rèn)省略)。

如果你需要格式化讀取的數(shù)據(jù),可以使用pretty()方法,語(yǔ)法格式如下:

db.collection.find().pretty()

pretty()方法以格式化的方式來(lái)顯示所有文檔。

2、實(shí)例

例如:查詢Student集合中的所有文檔。

除了find()方法之外,還有一個(gè)findOne()方法,它只返回一個(gè)文檔。

MongoDB與RDBMS where語(yǔ)句比較

如果你熟悉常規(guī)的SQL數(shù)據(jù),通過(guò)下表可以更好的理解MongoDB的條件語(yǔ)句查詢:

操作格式范例RDBMS中的類似語(yǔ)句
等于{<key>:<value>}db.Student.find({"name":"張三"}).pretty()where name='張三'
小于{<key>:{$lt:<value>}}db.Student.find({"score":{$lt:"80"}}).pretty()where score<80
小于或等于{<key>:{$lte:<value>}}db.Student.find({"score":{$lte:"80"}}).pretty()where score<=80
大于{<key>:{$gt:<value>}}db.Student.find({"score":{$gt:"80"}}).pretty()where score>80
大于或等于{<key>:{$gte:<value>}}db.Student.find({"score":{$gte:"80"}}).pretty()where score>=80
不等于{<key>:{$ne:<value>}}db.Student.find({"score":{$ne:"80"}}).pretty()where score!=80

(1)查詢name是張三的學(xué)生

db.Student.find({"name":"張三"}).pretty()

查詢結(jié)果如下圖所示:

(2)查詢成績(jī)小于80的學(xué)生

db.Student.find({"score":{$lt:"80"}}).pretty()

查詢結(jié)果如下圖所示:

(3)查詢成績(jī)小于等于80的學(xué)生

db.Student.find({"score":{$lte:"80"}}).pretty()

查詢結(jié)果如下圖所示:

(4)查詢成績(jī)大于80分的學(xué)生

db.Student.find({"score":{$gt:"80"}}).pretty()

(5)查詢成績(jī)大于等于80分的學(xué)生

db.Student.find({"score":{$gte:"80"}}).pretty()

查詢結(jié)果如下圖所示:

(6)查詢成績(jī)不等于80分的學(xué)生

db.Student.find({"score":{$ne:"80"}}).pretty()

查詢結(jié)果如下圖所示:

3、MongoDB AND條件查詢

MongoDB的find()方法可以傳入多個(gè)鍵(key),每個(gè)鍵(key)以逗號(hào)分隔開(kāi),等價(jià)于常規(guī)SQL的AND條件。

語(yǔ)法格式如下:

db.collection.find({key1:value1,key2:value2}).pretty()

例如:查詢姓名為張三并且課程是C#程序設(shè)計(jì)的學(xué)生信息。

db.Student.find({"name":"張三","subject":"C#程序設(shè)計(jì)"}).pretty()

查詢結(jié)果如下圖所示:

以上實(shí)例中類似于RDBMS中的where語(yǔ)句:WHERE name='張三' AND subject='C#程序設(shè)計(jì)'。

4、MongoDB OR 條件查詢

MongoDB的OR條件語(yǔ)句使用了關(guān)鍵字$or,語(yǔ)法格式如下:

>db.collection.find(
  {
    $or:[
           {key1:value1},{key2:value2}
        ]
   }
)

例如:查詢姓名是李四或者成績(jī)等于80的學(xué)生

db.Student.find({$or:[{"name":"李四"},{"score":"80"}]}).pretty()

查詢結(jié)果如下圖所示:

三、更新文檔

MongoDB使用update()和save()方法來(lái)更新集合中的文檔。接下來(lái)讓我們?cè)敿?xì)來(lái)看下兩個(gè)方法的應(yīng)用及其區(qū)別。

1、update()方法

update()方法用于更新已經(jīng)存在的文檔。語(yǔ)法格式如下:

db.collection.update(
  <query>,
  <update>,
 {
   upsert:<boolean>,
   multi:<boolean>,
   writeConcern:<document>
  }
)

參數(shù)說(shuō)明:

  • query:update的查詢條件,類似sql update查詢內(nèi)where后面的條件。
  • update:update的對(duì)象和一些更新的操作符(如$set,Sinc......)等,也可以理解為sql update查詢內(nèi)set后面的。
  • upsert:可選參數(shù),這個(gè)參數(shù)的意思是:如果不存在update的記錄,是否插入新的文檔。如果為true則插入,默認(rèn)是false不插入。
  • multi:可選參數(shù),MongoDB默認(rèn)是false,只更新找到的第一條記錄。如果這個(gè)參數(shù)為true,就把按條件查詢出來(lái)的多條記錄全部更新。
  • writeConcern:可選參數(shù),拋出異常的級(jí)別。

writeConcern的幾種拋出異常的級(jí)別參數(shù)

  • writeConcern.NONE:沒(méi)有異常拋出。
  • writeConcern.NORMAL:僅拋出網(wǎng)絡(luò)錯(cuò)誤異常,沒(méi)有服務(wù)器錯(cuò)誤異常拋出。
  • writeConcern.SAFE:拋出網(wǎng)絡(luò)錯(cuò)誤異常、服務(wù)器錯(cuò)誤異常;并等待服務(wù)器完成寫操作。
  • writeConcern.MAJORITY:拋出網(wǎng)絡(luò)錯(cuò)誤異常、服務(wù)器錯(cuò)誤異常;并等待一個(gè)主服務(wù)器完成寫操作。
  • writeConcern.FSYNC_SAFE:拋出網(wǎng)絡(luò)錯(cuò)誤異常、服務(wù)器錯(cuò)誤異常;寫操作等待服務(wù)器將數(shù)據(jù)刷新到磁盤。
  • writeConcern.JOURNAL_SAFE:拋出網(wǎng)絡(luò)錯(cuò)誤異常、服務(wù)器錯(cuò)誤異常;寫操作等待服務(wù)器提交到磁盤的日志文件。
  • writeConcern.REPLICAS_SAFE:拋出網(wǎng)絡(luò)錯(cuò)誤異常、服務(wù)器錯(cuò)誤異常;等待至少2臺(tái)服務(wù)器完成寫操作。

例如:使用update()方法更新標(biāo)題(title)

上面的語(yǔ)句只會(huì)更新第一條查詢到的文檔,如果你要更新多條相同的文檔,則需要設(shè)置multi參數(shù)為true。

如果要更新的數(shù)據(jù)不存在,upsert參數(shù)設(shè)置為true則會(huì)插入數(shù)據(jù)。

2、save()方法

save()方法通過(guò)傳入的文檔來(lái)替換已有文檔,語(yǔ)法格式如下:

db.collection.save(
  <document>,
  {
    writeConcern:<document>
  }
)

參數(shù)說(shuō)明:

  • document:要更新的文檔數(shù)據(jù)。
  • writeConcern:可選參數(shù),拋出異常的級(jí)別。

例如:更新_id=5a702a7f2c6ed8f4d3491831的文檔。

四、刪除文檔

MongoDB使用remove()方法來(lái)移除集合中的數(shù)據(jù)。

注意:在執(zhí)行remove()方法前先執(zhí)行find()命令來(lái)判斷執(zhí)行的條件是否正確,這是一個(gè)比較好的習(xí)慣。

remove()方法的基本語(yǔ)法格式如下:

db.collection.remove(
  <query>,
  <justOne>
)

如果MongoDB是2.6版本以后的,語(yǔ)法格式如下:

db.collection.remove(
  <query>,
  {
    justOne:<boolean>,
    writeConcern:<document>
   }
)

參數(shù)說(shuō)明:

  • query:可選參數(shù),刪除文檔的條件。
  • justOne:可選參數(shù),如果設(shè)為true或1,則只刪除一個(gè)文檔。
  • writeConcern:可選參數(shù),拋出異常的級(jí)別。

實(shí)例

1、刪除title為MongoDB教程的文檔,只刪除一個(gè):

2、刪除所有數(shù)據(jù)

如果想刪除所有數(shù)據(jù),可以使用下面的例子

到此這篇關(guān)于使用MongoDB操作文檔的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持本站。

香港快速服務(wù)器

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部