MongoDB基本操作(增删改查)
2019獨角獸企業重金招聘Python工程師標準>>>
基本操作
? ? ?基本的“增刪查改“,在DOS環境下輸入mongo命令打開shell,其實這個shell就是mongodb的客戶端,同時也是一個js的編譯器,默認連接的是“test”數據庫。
?
?
【出錯】
首先當我們用同樣的方式打開mongodb,竟然開啟不了,仔細觀察“劃線區域“的信息,發現db文件夾下有一個類似的”lock file”阻止了mongodb的開啟,接下來我們要做的就是干掉它,之后,開啟成功。
<1> insert 操作
數據庫有了,下一步就是集合,這里就取集合名為“person”,要注意的就是文檔是一個json的擴展(Bson)形式。
注意:書寫格式為外面是(),里面的書{}。
?
文檔是采用“K-V”格式存儲的,如果大家對JSON比較熟悉的話,我相信學mongodb是手到擒來,我們知道JSON里面Value可能是“字符串”,可能是“數組”,又有可能是內嵌的一個JSON對象,相同的方式也適合于BSON。
常見的插入操作也就兩種形式存在:“單條插入”和“批量插入”。
① 單條插入
先前也說了,mongo命令打開的是一個javascript shell。所以js的語法在這里面都行得通,看起來是不是很牛X。
?
? ?
② 批量插入
這玩意跟“單條插入”的差異相信大家應該知道,由于mongodb中沒有提供給shell的“批量插入方法”,沒關系,各個語言的driver都打通
了跟mongodb內部的批量插入方法,因為該方法是不可或缺的,如果大家非要模擬下批量插入的話,可以自己寫了for循環,里面就是insert。
? ?
??<2> find 操作
我們將數據插入后,肯定是要find出來,不然插了也白插,這里要注意兩點:
① “_id": 這個字段是數據庫默認給我們加的GUID,目的就是保證數據的唯一性。
② 嚴格的按照Bson的形式書寫文檔,不過也沒關系,錯誤提示還是很強大的。
?
?
日常開發中,我們玩查詢,玩的最多的也就是二類:
①: >, >=, <, <=, !=, =。
②:And,OR,In,NotIn
這些操作在mongodb里面都封裝好了,下面就一一介紹:
<1>"$gt", "$gte", "$lt", "$lte", "$ne", "沒有特殊關鍵字",這些跟上面是一一對應的,舉幾個例子。
?
<2> "無關鍵字“, "$or", "$in","$nin" 同樣我也是舉幾個例子
?
<3> 在mongodb中還有一個特殊的匹配,那就是“正則表達式”,這玩意威力很強的。
?
<4> 有時查詢很復雜,很蛋疼,不過沒關系,mongodb給我們祭出了大招,它就是$where,為什么這么說,是因為$where中的value就是我們非常熟悉,非常熱愛的js來助我們一馬平川。
?
?
<3> update操作
? ? ? ? ? update方法的第一個參數為“查找的條件”,第二個參數為“更新的值”。
?
?
更新操作無非也就兩種,整體更新和局部更新,使用場合相信大家也清楚。
<1> 整體更新
不知道大家可還記得,我在上一篇使用update的時候,其實那種update是屬于整體更新。
?
<2> 局部更新
有時候我們僅僅需要更新一個字段,而不是整體更新,那么我們該如何做呢?easy的問題,mongodb中已經給我們提供了兩個修改器: $inc 和 $set。
① $inc修改器
$inc也就是increase的縮寫,學過sql server 的同學應該很熟悉,比如我們做一個在線用戶狀態記錄,每次修改會在原有的基礎上自增$inc指定的值,如果“文檔”中沒有此key,則會創建key,下面的例子一看就懂。
?
② $set修改器
?
<3> upsert操作
這個可是mongodb創造出來的“詞”,大家還記得update方法的第一次參數是“查詢條件”嗎?,那么這個upsert操作就是說:如果我沒有查到,我就在數據庫里面新增一條,其實這樣也有好處,就是避免了我在數據庫里面判斷是update還是add操作,使用起來很簡單。將update的第三個參數設為true即可。
?
<4> 批量更新
在mongodb中如果匹配多條,默認的情況下只更新第一條,那么如果我們有需求必須批量更新,那么在mongodb中實現也是很簡單的,在update的第四個參數中設為true即可。例子就不舉了。
?
<4> remove操作
remove中如果不帶參數將刪除所有數據,很危險的操作,在mongodb中是一個不可撤回的操作,三思而后行。
?
轉載于:https://my.oschina.net/u/2312175/blog/635241
總結
以上是生活随笔為你收集整理的MongoDB基本操作(增删改查)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: github 上微信判断是否被删除的源码
- 下一篇: 作业四:产品同质化问题