前面的話
本文將詳細(xì)介紹MongoDB數(shù)據(jù)庫(kù)關(guān)于文檔的增刪改查
如果數(shù)據(jù)庫(kù)中不存在集合,則MongoDB將創(chuàng)建此集合,然后將文檔插入到該集合中
要在單個(gè)查詢中插入多個(gè)文檔,可以在insert()
命令中傳遞文檔數(shù)組
可以使用js語(yǔ)法,插入多個(gè)文檔
【save()】
插入文檔也可以使用db.post.save(document)。 如果不在文檔中指定_id,那么save()方法將與insert()方法一樣自動(dòng)分配ID的值。如果指定_id,則將以save()方法的形式替換包含_id的文檔的全部數(shù)據(jù)。
也就是說(shuō)save()方法和insert()方法的區(qū)別是,save()方法可以復(fù)寫或修改,而insert()方法不可以
【insertOne()】
使用db.collection.insertOne()
方法可以將單個(gè)文檔插入到集合中
【insertMany()】
使用db.collection.insertMany()
方法可以將多個(gè)文檔插入到集合中
查詢文檔
【find()】
要從MongoDB集合查詢數(shù)據(jù),需要使用MongoDB的find()
方法,默認(rèn)返回結(jié)果中的前20條文檔,輸入"it"顯示接下來(lái)的20條文檔。
find()
命令的基本語(yǔ)法如下:
db.COLLECTION_NAME.find(document)
find()
方法將以非結(jié)構(gòu)化的方式顯示所有文檔
可以限定查詢條件
可以通過(guò)find 的第二個(gè)參數(shù)來(lái)指定返回的鍵,值為1或true表示顯示該鍵,值為0或false表示不顯示該鍵
find()方法下的count()方法可以顯示符合條件的文檔數(shù)量
【findOne()】
findOne()
方法只返回一個(gè)文檔,該文檔是最早被添加的文檔
【比較操作符】
小于 {key>:{$lt:value>}}
小于或等于 {key>:{$lte:value>}}
大于 {key>:{$gt:value>}}
大于或等于 {key>:{$gte:value>}}
不等于 {key>:{$ne:value>}}
等于 {key>:{$eq:value>}}
取得x小于2的值
取得x大于等于2的值
取得x不等于2的值
【邏輯操作符】
可以使用邏輯操作符$and、$or來(lái)表示與、或
{ $and: [ { expression1> }, { expression2> } , ... , { expressionN> } ] }
{ $nor: [ { expression1> }, { expression2> }, ... { expressionN> } ] }
【正則表達(dá)式】
文檔查詢可以使用正則表達(dá)式,但只支持字符串類型的數(shù)據(jù)
【$where】
$where操作符功能強(qiáng)大而且靈活,它可以使用任意的JavaScript作為查詢的一部分,包含JavaScript表達(dá)式的字符串或者JavaScript函數(shù)
使用字符串
使用函數(shù)
限制與跳過(guò)
【limit()】
如果需要在MongoDB中讀取指定數(shù)量的數(shù)據(jù)記錄,可以使用MongoDB的Limit方法,limit()方法接受一個(gè)數(shù)字參數(shù),該參數(shù)指定從MongoDB中讀取的記錄條數(shù)
默認(rèn)返回結(jié)果中的前20條文檔,輸入"it"顯示接下來(lái)的20條文檔
如果沒有指定limit()方法中的參數(shù)則顯示集合中的所有數(shù)據(jù)
db.COLLECTION_NAME.find().limit(NUMBER)
【skip()】
可以使用skip()方法來(lái)跳過(guò)指定數(shù)量的數(shù)據(jù),skip方法同樣接受一個(gè)數(shù)字參數(shù)作為跳過(guò)的記錄條數(shù)
db.COLLECTION_NAME.find().skip(NUMBER)
排序
【sort()】
在MongoDB中使用sort()方法對(duì)數(shù)據(jù)進(jìn)行排序,sort()方法可以通過(guò)參數(shù)指定排序的字段,并使用 1 和 -1 來(lái)指定排序的方式,其中 1 為升序排列,而-1是用于降序排列
db.COLLECTION_NAME.find().sort({KEY:1})
更新文檔
MongoDB 使用update()或save()方法來(lái)更新集合中的文檔
【update()】
update() 方法用于更新已存在的文檔。語(yǔ)法格式如下:
db.collection.update(query>,update>,{upsert:boolean>, multi: boolean>,writeConcern:document>})
query : update的查詢條件,類似sql update查詢內(nèi)where后面的
update : update的對(duì)象和一些更新的操作符(如$,$inc...)等,也可以理解為sql update查詢內(nèi)set后面的
upsert : 可選,這個(gè)參數(shù)的意思是,如果不存在update的記錄,是否插入objNew,true為插入,默認(rèn)是false,不插入
multi : 可選,mongodb 默認(rèn)是false,只更新找到的第一條記錄,如果這個(gè)參數(shù)為true,就把按條件查出來(lái)多條記錄全部更新
writeConcern :可選,拋出異常的級(jí)別
[注意]經(jīng)過(guò)測(cè)試,upsert參數(shù)無(wú)法設(shè)置為true或者false,都可以插入新的字段
mongodb默認(rèn)只更新找到的第一條記錄,將x:1,更新為x:10
要特別注意的是,如果不使用$set,則將文檔的內(nèi)容替換為x:10
更新全部記錄,將x:10,更新為x:1
mongodb默認(rèn)只添加到更新找到的第一條記錄,將x:1的記錄,添加z:1
將找到的x:2的全部記錄,添加z:2
【save()】
save()方法可以插入或更新文檔,如果參數(shù)中的文檔的_id與集合中所存在的_id都不同,則插入;如果相同,則更新
刪除文檔
MongoDB remove()函數(shù)是用來(lái)移除集合中的數(shù)據(jù)
【remove()】
默認(rèn)地,mongodb刪除符合條件的所有文檔
db.collection.remove(query>,{justOne: boolean>, writeConcern: document>})
query :刪除的文檔的條件。
justOne : (可選)如果設(shè)為 true 或 1,則只刪除一個(gè)文檔。
writeConcern :(可選)拋出異常的級(jí)別。
只刪除符合條件的第一個(gè)文檔
刪除符合條件的所有文檔
插入文檔
要將數(shù)據(jù)插入到 MongoDB 集合中,需要使用 MongoDB 的 insert()或save()方法,還有insertOne()或insertMany()方法
【insert()】
insert()命令的基本語(yǔ)法如下
db.COLLECTION_NAME.insert(document)
在插入的文檔中,如果不指定_id參數(shù),那么 MongoDB 會(huì)為此文檔分配一個(gè)唯一的ObjectId。_id為集合中的每個(gè)文檔唯一的12個(gè)字節(jié)的十六進(jìn)制數(shù)
以上這篇MongoDB數(shù)據(jù)庫(kù)文檔操作方法(必看篇)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB訪問(wèn)控制的操作方法
- 分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB備份與恢復(fù)的實(shí)踐詳解
- 分布式文檔存儲(chǔ)數(shù)據(jù)庫(kù)之MongoDB分片集群的問(wèn)題
- SpringDataMongoDB多文檔事務(wù)的實(shí)現(xiàn)
- mongodb如何對(duì)文檔內(nèi)數(shù)組進(jìn)行過(guò)濾的方法步驟
- MongoDB中文檔的更新操作示例詳解
- mongodb 數(shù)據(jù)類型(null/字符串/數(shù)字/日期/內(nèi)嵌文檔/數(shù)組等)
- PHP庫(kù) 查詢Mongodb中的文檔ID的方法
- MongoDB如何更新多級(jí)文檔的數(shù)據(jù)