日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

MongoDB基本操作(增删改查)

發(fā)布時(shí)間:2023/12/4 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MongoDB基本操作(增删改查) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>

基本操作

? ? ?基本的“增刪查改“,在DOS環(huán)境下輸入mongo命令打開shell,其實(shí)這個(gè)shell就是mongodb的客戶端,同時(shí)也是一個(gè)js的編譯器默認(rèn)連接的是“test”數(shù)據(jù)庫

?

?

【出錯(cuò)】

  首先當(dāng)我們用同樣的方式打開mongodb,竟然開啟不了,仔細(xì)觀察“劃線區(qū)域“的信息,發(fā)現(xiàn)db文件夾下有一個(gè)類似的”lock file”阻止了mongodb的開啟,接下來我們要做的就是干掉它,之后,開啟成功。

<1> insert 操作

數(shù)據(jù)庫有了,下一步就是集合,這里就取集合名為“person”,要注意的就是文檔是一個(gè)json的擴(kuò)展(Bson)形式。

注意:書寫格式為外面是(),里面的書{}。

?

文檔是采用“K-V”格式存儲的,如果大家對JSON比較熟悉的話,我相信學(xué)mongodb是手到擒來,我們知道JSON里面Value可能是“字符串”,可能是“數(shù)組”,又有可能是內(nèi)嵌的一個(gè)JSON對象,相同的方式也適合于BSON。

常見的插入操作也就兩種形式存在:“單條插入”和“批量插入”。

① 單條插入

先前也說了,mongo命令打開的是一個(gè)javascript shell。所以js的語法在這里面都行得通,看起來是不是很牛X。

?

? ?

② 批量插入

這玩意跟“單條插入”的差異相信大家應(yīng)該知道,由于mongodb中沒有提供給shell的“批量插入方法”,沒關(guān)系,各個(gè)語言的driver都打通

了跟mongodb內(nèi)部的批量插入方法,因?yàn)樵摲椒ㄊ遣豢苫蛉钡?#xff0c;如果大家非要模擬下批量插入的話,可以自己寫了for循環(huán),里面就是insert。

? ?

??<2> find 操作

我們將數(shù)據(jù)插入后,肯定是要find出來,不然插了也白插,這里要注意兩點(diǎn):

① “_id": 這個(gè)字段是數(shù)據(jù)庫默認(rèn)給我們加的GUID,目的就是保證數(shù)據(jù)的唯一性。

② 嚴(yán)格的按照Bson的形式書寫文檔,不過也沒關(guān)系,錯(cuò)誤提示還是很強(qiáng)大的。

?

?

日常開發(fā)中,我們玩查詢,玩的最多的也就是二類:

①: >, >=, <, <=, !=, =。

②:And,OR,In,NotIn

這些操作在mongodb里面都封裝好了,下面就一一介紹:

<1>"$gt", "$gte", "$lt", "$lte", "$ne", "沒有特殊關(guān)鍵字",這些跟上面是一一對應(yīng)的,舉幾個(gè)例子。

?

<2> "無關(guān)鍵字“, "$or", "$in","$nin" 同樣我也是舉幾個(gè)例子

?

<3> 在mongodb中還有一個(gè)特殊的匹配,那就是“正則表達(dá)式”,這玩意威力很強(qiáng)的。

?

<4> 有時(shí)查詢很復(fù)雜,很蛋疼,不過沒關(guān)系,mongodb給我們祭出了大招,它就是$where,為什么這么說,是因?yàn)?where中的value就是我們非常熟悉,非常熱愛的js來助我們一馬平川。

?

?

<3> update操作

? ? ? ? ? update方法的第一個(gè)參數(shù)為“查找的條件”,第二個(gè)參數(shù)為“更新的值”。

?

?

更新操作無非也就兩種,整體更新和局部更新,使用場合相信大家也清楚。

<1> 整體更新

不知道大家可還記得,我在上一篇使用update的時(shí)候,其實(shí)那種update是屬于整體更新。

?

<2> 局部更新

有時(shí)候我們僅僅需要更新一個(gè)字段,而不是整體更新,那么我們該如何做呢?easy的問題,mongodb中已經(jīng)給我們提供了兩個(gè)修改器: $inc 和 $set。

① $inc修改器

$inc也就是increase的縮寫,學(xué)過sql server 的同學(xué)應(yīng)該很熟悉,比如我們做一個(gè)在線用戶狀態(tài)記錄,每次修改會在原有的基礎(chǔ)上自增$inc指定的值,如果“文檔”中沒有此key,則會創(chuàng)建key,下面的例子一看就懂。

?

② $set修改器

?

<3> upsert操作

這個(gè)可是mongodb創(chuàng)造出來的“詞”,大家還記得update方法的第一次參數(shù)是“查詢條件”嗎?,那么這個(gè)upsert操作就是說:如果我沒有查到,我就在數(shù)據(jù)庫里面新增一條,其實(shí)這樣也有好處,就是避免了我在數(shù)據(jù)庫里面判斷是update還是add操作,使用起來很簡單。將update的第三個(gè)參數(shù)設(shè)為true即可。

?

<4> 批量更新

在mongodb中如果匹配多條,默認(rèn)的情況下只更新第一條,那么如果我們有需求必須批量更新,那么在mongodb中實(shí)現(xiàn)也是很簡單的,在update的第四個(gè)參數(shù)中設(shè)為true即可。例子就不舉了。

?

<4> remove操作

remove中如果不帶參數(shù)將刪除所有數(shù)據(jù),很危險(xiǎn)的操作,在mongodb中是一個(gè)不可撤回的操作,三思而后行。

?

轉(zhuǎn)載于:https://my.oschina.net/u/2312175/blog/635241

總結(jié)

以上是生活随笔為你收集整理的MongoDB基本操作(增删改查)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。