MongoDB數(shù)據(jù)庫(kù)插入、更新和刪除操作

Insert操作

Insert操作是MongoDB插入數(shù)據(jù)的基本方法,對(duì)目標(biāo)集合使用Insert操作,會(huì)將該文檔添加到MongoDB并自動(dòng)生成相應(yīng)的ID鍵。文檔結(jié)構(gòu)采用類似JSON的BSON格式。插入時(shí)只是簡(jiǎn)單地將文檔存入數(shù)據(jù)庫(kù)中,不進(jìn)行額外的驗(yàn)證,也不會(huì)執(zhí)行代碼,所以不存在注入式攻擊的可能。

插入操作主要有單條插入和批量插入兩種形式

1.1 單條插入操作


insert_single.png
db.col.insert({field1:"",field2:"",field3:"",...});

1.2 批量插入操作

MongoDB對(duì)批量插入的支持是通過傳遞多個(gè)文檔組成的數(shù)組到數(shù)據(jù)庫(kù)來(lái)實(shí)現(xiàn)的。

Paste_Image.png
var feeds = [
{_id:"10003", uid:"10001", name:"wills","msg":"這個(gè)平臺(tái)不錯(cuò)的,可以常來(lái)幫助別人的.",state:"0"},
{_id:"10004", uid:"10001", name:"wills","msg":"你們的平臺(tái)的詳情頁(yè)有點(diǎn)問題哦.",state:"0"},
{_id:"10005", uid:"10001", name:"wills","msg":"這是一個(gè)助人的平臺(tái),值得擁有的.",state:"0"},
{_id:"10006", uid:"10001", name:"wills","msg":"好的平臺(tái)還是需要更多人知道的.",state:"0"}
]

db.col.insert(feeds)

這種方式的批量插入一次只能將多個(gè)文檔插入到一個(gè)集合中,對(duì)于插入到多個(gè)集合可以循環(huán)調(diào)用Insert操作。

Remove操作

remove函數(shù)可以用來(lái)刪除數(shù)據(jù),它能接受一個(gè)文檔作為可選參數(shù),只有符合條件的文檔才會(huì)被刪除。

刪除數(shù)據(jù)是永久性的,不能撤銷,也不能恢復(fù),需要謹(jǐn)慎。刪除文檔需要清空整個(gè)集合,不如直接刪除集合快。

//刪除name為wills的數(shù)據(jù)
db.col.remove({name:"wills"})

//全部刪除整個(gè)集合
db.col.remove({});

Update操作

update函數(shù)用于修改數(shù)據(jù)庫(kù)中的數(shù)據(jù),它接收兩個(gè)參數(shù),一個(gè)是查詢文檔,用來(lái)查找要更新的文檔,另一個(gè)是修改器文檔,用來(lái)描述對(duì)找到的文檔做哪些修改。

更新操作是原子性的,如果多個(gè)更新同時(shí)發(fā)生,則所有的更新都會(huì)執(zhí)行,但只有最后的更新才起效果。

/*
db.collection.update( criteria, objNew, upsert, multi )
criteria : update的查詢條件,類似sql update查詢內(nèi)where后面的
objNew   : 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)多條記錄全部更新。
*/

db.col.update( { "count" : { $gt : 1 } } , { $set : { "test2" : "OK"} } ); 只更新了第一條記錄
db.col.update( { "count" : { $gt : 3 } } , { $set : { "test2" : "OK"} },false,true ); 全更新了
db.col.update( { "count" : { $gt : 4 } } , { $set : { "test5" : "OK"} },true,false ); 只加進(jìn)去了第一條
db.col.update( { "count" : { $gt : 5 } } , { $set : { "test5" : "OK"} },true,true ); 全加進(jìn)去了
db.col.update( { "count" : { $gt : 15 } } , { $inc : { "count" : 1} },false,true );全更新了
db.col.update( { "count" : { $gt : 10 } } , { $inc : { "count" : 1} },false,false );只更新了第一條

mongodb的更新操作符:

1) $inc

用法:{ $inc : { field : value } }意思對(duì)一個(gè)數(shù)字字段field增加value

db.col.update( { "name" : "wills" } , { $inc : { "age" : 1 } } );

2) $set

用法:{ $set : { field : value } },就是相當(dāng)于sql的set field = value,全部數(shù)據(jù)類型都支持$set。

db.col.update({name:"wills"},{$set: {age: 30}});

3) $unset

用法:{ $unset : { field : 1} }顧名思義,就是刪除字段

db.col.update({name:"wills"}, {$unset: {age:1}});

4) $push

用法:{ $push : { field : value } },把value追加到field里面去,field一定要是數(shù)組類型才行,如果field不存在,會(huì)新增一個(gè)數(shù)組類型加進(jìn)去

 db.col.update( { "name" : "wills" } , { $push : { "books": "nosql" } } );

5) $pushAll

用法:{ $pushAll : { field : value_array } },同$push,只是一次可以追加多個(gè)值到一個(gè)數(shù)組字段內(nèi)。

 db.col.update( { "name" : "wills" } , { $pushAll : { "books": [ "nosql","mysql"] } } );

6) $addToSet

用法:{ $addToSet : { field : value } },增加一個(gè)值到數(shù)組內(nèi),而且只有當(dāng)這個(gè)值不在數(shù)組內(nèi)才增加。

db.col.update( { "name" : "wills" } , { $addToSet : { "books": {$each : ["python","nodejs"] } } } );

7) $pop

刪除數(shù)組內(nèi)的一個(gè)值用法:
刪除最后一個(gè)值:{ $pop : { field : 1 } }
刪除第一個(gè)值:{ $pop : { field : -1 } }
注意,只能刪除一個(gè)值,也就是說只能用1或-1

db.col.update( { "name" : "wills"} , { $pop : { "books": -1 } } );

8) $pull

用法:$pull : { field : value } }從數(shù)組field內(nèi)刪除一個(gè)等于value值。

db.col.update( { "name" : "wills"} , { $pull : { "books": "nodejs" } } );

9) $pullAll

用法:{ $pullAll : { field : value_array } }同$pull,可以一次刪除數(shù)組內(nèi)的多個(gè)值

db.col.update( { "name" : "wills" } , { $pullAll : { "books": [ "nosql" , "mysql" ] } } );

10) $ 操作符

$是他自己的意思,代表按條件找出的數(shù)組里面某項(xiàng)他自己

> t.find()
//{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 3 }, { "by" : "jane", "votes" : 7 } ] }
> t.update( {'comments.by':'joe'}, {$inc:{'comments.$.votes':1}}, false, true)
> t.find()
//{ "_id" : ObjectId("4b97e62bf1d8c7152c9ccb74"), "title" : "ABC", "comments" : [ { "by" : "joe", "votes" : 4 }, { "by" : "jane", "votes" : 7 } ] }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,680評(píng)論 19 139
  • 上一篇了解了Mongodb基本常識(shí),下面繼續(xù): 一、查詢語(yǔ)句: find() 用法: 查詢數(shù)據(jù),不加任何參數(shù)默認(rèn)返...
    多了去的YangXuLei閱讀 529評(píng)論 0 3
  • NoSql數(shù)據(jù)庫(kù)優(yōu)缺點(diǎn) 在優(yōu)勢(shì)方面主要體現(xiàn)在下面幾點(diǎn): 簡(jiǎn)單的擴(kuò)展 快速的讀寫 低廉的成本 靈活的數(shù)據(jù)模型 在不足...
    dreamer_lk閱讀 2,878評(píng)論 0 6
  • 姓名:冉喬琪~公司:天興醫(yī)藥 【日精進(jìn)打卡第※91※天】 【知~學(xué)習(xí)】 《六項(xiàng)精進(jìn)》2遍 共296遍 《大學(xué)》2遍...
    小小新醬閱讀 300評(píng)論 0 0
  • 最近公司的一臺(tái)服務(wù)器頻繁報(bào)警,老大讓我研究下代碼出了什么問題,咋一看才知道代碼是用大名鼎鼎的異步框架Vert.x寫...
    j4fan閱讀 3,028評(píng)論 0 1

友情鏈接更多精彩內(nèi)容