小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

8天學(xué)通MongoDB——第二天 細(xì)說增刪查改

 fshell 2013-05-14

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

傻眼了,擦,竟然開啟不了,仔細(xì)觀察“劃線區(qū)域“的信息,發(fā)現(xiàn)db文件夾下有一個(gè)類似的”lock file”阻止了mongodb的開啟,接下來我們要做的就

是干掉它,之后,開啟成功,關(guān)于mongodb的管理方式將在后續(xù)文章分享。

 

一: Insert操作

     上一篇也說過,文檔是采用“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)樵摲椒ㄊ遣豢苫蛉钡?,如果大家非要模擬下批量插入的話,可以自己寫了for循環(huán),里面就是insert。

 

二:Find操作

     日常開發(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來助我們一馬平川。

 

三:Update操作

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

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

 

四: Remove操作

      這個(gè)操作在上一篇簡單的說過,這里就不贅述了。

    本站是提供個(gè)人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多