8天學通MongoDB——第二天 細說增刪查改

來源:互聯網
上載者:User

      看過上一篇,相信大家都會知道如何開啟mongodb了,這篇就細說下其中的增刪查改,首先當我們用上一篇同樣的方式開啟mongodb,突然

傻眼了,擦,竟然開啟不了,仔細觀察“劃線地區“的資訊,發現db檔案夾下有一個類似的”lock file”阻止了mongodb的開啟,接下來我們要做的就

是幹掉它,之後,開啟成功,關於mongodb的管理方式將在後續文章分享。

 

一: Insert操作

     上一篇也說過,文檔是採用“K-V”格式儲存的,如果大家對JSON比較熟悉的話,我相信學mongodb是手到擒來,我們知道JSON裡面Value

可能是“字串”,可能是“數組”,又有可能是內嵌的一個JSON對象,相同的方式也適合於BSON。

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

   

    ①  單條插入

          先前也說了,mongo命令開啟的是一個javascript shell。所以js的文法在這裡面都行得通,看起來是不是很牛X。      

    

   ② 批量插入

      這玩意跟“單條插入”的差異相信大家應該知道,由於mongodb中沒有提供給shell的“批量插入方法”,沒關係,各個語言的driver都打通

了跟mongodb內部的批量插入方法,因為該方法是不可或缺的,如果大家非要類比下批量插入的話,可以自己寫了for迴圈,裡面就是insert。

 

二:Find操作

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

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

     ②:And,OR,In,NotIn

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

    <1>"$gt", "$gte", "$lt", "$lte", "$ne", "沒有特殊關鍵字",這些跟上面是一一對應的,舉幾個例子。

   

<2> "無關鍵字“, "$or", "$in","$nin" 同樣我也是舉幾個例子

 

  

<3> 在mongodb中還有一個特殊的匹配,那就是“Regex”,這玩意威力很強的。

 

<4> 有時查詢很複雜,很蛋疼,不過沒關係,mongodb給我們祭出了大招,它就是$where,為什麼這麼說,是因為$where中的value

  就是我們非常熟悉,非常熱愛的js來助我們一馬平川。

 

三: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即可。例子就不舉了。

 

四: Remove操作

      這個操作在上一篇簡單的說過,這裡就不贅述了。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.