欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mongodb使用心得簡單總結(jié)

 更新時(shí)間:2016年01月30日 12:48:57   投稿:hebedich  
本文整理了一年多以來我常用的MongoDB操作,既有運(yùn)維層面也有應(yīng)用層面,內(nèi)容有淺有深,這也就是我從零到熟練的歷程。

1.mongodb特性

1)mongo是一個(gè)面向文檔的數(shù)據(jù)庫,它集合了nosql和sql數(shù)據(jù)庫兩方面的特性。
2)所有實(shí)體都是在首次使用時(shí)創(chuàng)建。
3)沒有嚴(yán)格的事務(wù)特性,但是它保證任何一次數(shù)據(jù)變更都是原子性的。
4)也沒有固定的數(shù)據(jù)模型
5)mongo以javascript作為命令行執(zhí)行引擎,所以利用shell進(jìn)行復(fù)雜的計(jì)算和查詢時(shí)會(huì)相當(dāng)?shù)穆?br /> 6)mongo本身支持集群和數(shù)據(jù)分片
7)mongo是c++實(shí)現(xiàn)的,支持windows mac linux等主流操作系統(tǒng)
8)性能優(yōu)越,速度快

2.mongo常用操作

1.增刪操作

  1.    db.user.insert({name:'aaaa',age:30});
  2.    db.user.save({name:'aaaa',age:30});
  3.    db.collection.insertOne({});(3.2新特性)
  4.    db.collection.deleteOne(<filter>,{});(3.2新特性)
  5.    db.collection.remove({name:'aaa'});
  6.    db.collection.remove();(刪除全部)
  7.   

2.更新操作

  1.   db.users.update ({   " name"   :   "joe"   },   joe );
  2.   db.users.update ({   " name"   :   "joe"   },   joe,  true );------upsert模式
  3.   db.users.update ({   " name"   :   "joe"   },   joe,  true ,true);------MULTI模式

update是對(duì)文檔替換,而不是局部修改默認(rèn)情況update更新匹配的第一條文檔,multi模式更新所有匹配的

3.查詢操作

  -- 普通查詢

  1.   db.user.find();
  2.   db.user.find({name:'aaa'});
  3.   db.user.findOne({name:'aaa'});

  -- 模糊查詢

  1.   db.UserInfo.find({userName :/A/}) (名稱%A%)
  2.   db.UserInfo.find({userName :/^A/}) (名稱A%)

4.操作符

    1.$lt, $lte,$gt, $gte(<, <=, >, >= )    
    2.$all    數(shù)組中的元素是否完全匹配  db.things.find( { a: { $all: [ 2, 3 ] } } );
    3.$exists  可選:true,false  db.things.find( { a : { $exists : true } } );
    4.$mod  取模:a % 10 == 1  db.things.find( { a : { $mod : [ 10 , 1 ] } } );
    5.$ne 取反:即not equals  db.things.find( { x : { $ne : 3 } } );
    6.$in 類似于SQL的IN操作  db.things.find({j:{$in: [2,4,6]}});
    7.$nin $in的反操作,即SQL的  NOT IN  db.things.find({j:{$nin: [2,4,6]}});
    8.$nor $or的反操作,即不匹配(a或b)  db.things.find( { name : "bob", $nor : [ { a : 1 },{ b : 2 }]})
    9.$or Or子句,注意$or不能嵌套使用  db.things.find( { name : "bob" , $or : [ { a : 1 },{ b : 2 }]})
    10.$size  匹配數(shù)組長度  db.things.find( { a : { $size: 1 } } );
    11.$type  匹配子鍵的數(shù)據(jù)類型,詳情請看  db.things.find( { a : { $type : 2 } } );

5.數(shù)組查詢

    $size 用來匹配數(shù)組長度(即最大下標(biāo)) 
    // 返回comments包含5個(gè)元素的文檔  
    db.posts.find({}, {comments:{‘$size': 5}}); 
    // 使用冗余字段來實(shí)現(xiàn) 
    db.posts.find({}, {‘commentCount': { ‘$gt': 5 }});  
    $slice 操作符類似于子鍵篩選,只不過它篩選的是數(shù)組中的項(xiàng) 
    // 僅返回?cái)?shù)組中的前5項(xiàng) 
    db.posts.find({}, {comments:{‘$slice': 5}}); 
    // 僅返回?cái)?shù)組中的最后5項(xiàng) 
    db.posts.find({}, {comments:{‘$slice': -5}}); 
    // 跳過數(shù)組中的前20項(xiàng),返回接下來的10項(xiàng) 
    db.posts.find({}, {comments:{‘$slice': [20, 10]}}); 
    // 跳過數(shù)組中的最后20項(xiàng),返回接下來的10項(xiàng) 
    db.posts.find({}, {comments:{‘$slice': [-20, 10]}}); 
    MongoDB 允許在查詢中指定數(shù)組的下標(biāo),以實(shí)現(xiàn)更加精確的匹配 
    // 返回comments中第1項(xiàng)的by子鍵為Abe的所有文檔 
    db.posts.find( { "comments.0.by" : "Abe" } );  

3.索引的使用

1.創(chuàng)建索引

    db.things.ensureIndex ({'j': 1});
    創(chuàng)建子文檔 索引
    db.things.ensureIndex ({'user.Name' : - 1});
    創(chuàng)建 復(fù)合 索引
    db.things.ensureIndex ({
    'j' : 1 ,   //  升序
    'x' : - 1   //  降序
    });
    如果 您的 find 操作只用到了一個(gè)鍵,那么索引方向是無關(guān)緊要的 
    當(dāng)創(chuàng)建復(fù)合索引的時(shí)候,一定要謹(jǐn)慎斟酌每個(gè)鍵的排序方向

2.修改索引

    修改索引,只需要重新 運(yùn)行索引 命令即可 
    如果索引已經(jīng)存在則會(huì) 重建, 不存在的索引會(huì)被 添加 
    db . things . ensureIndex ({
        --- 原來的索引會(huì) 重建
        'user.Name ' :   - 1 ,
        --- 新增一個(gè)升序 索引
        'user.Name ' :   1 ,
        ---  為 Age 新建降序 索引
        'user.Age ' :   - 1
    },
    打開后臺(tái)執(zhí)行
    {    ‘background' :   true}
    );
    重建索引
    db. things .reIndex();   

3.刪除索引

    刪除集合中的所有 索引
    db . things . dropIndexes (); 
    刪除指定鍵的索引 
    db.things.dropIndex ({
        x :   1 ,
        y :   - 1
    }); 
    使用 command 刪除指定鍵的 索引
    db.runCommand ({
        dropIndexes : 'foo ' ,
        index  :   {   y :   1   }
    }); 
    使用 command 刪除所有 索引
    db . runCommand ({dropIndexes : 'foo ' ,index  :   '*‘})
    如果是刪除集合中所有的文檔(remove)則不會(huì)影響索引,當(dāng)有新文檔插入時(shí),索引就會(huì)重建。

4.唯一索引

    創(chuàng)建唯一索引,同時(shí)這也是一個(gè)符合唯一索引 
    db.things.ensureIndex (
    {
        'firstName ' :   1 ,
        'lastName ' :   1
    },   {
    指定為唯一索引
    'unique ' :   true ,
    刪除重復(fù) 記錄
    'dropDups ' :   true
    });

5、強(qiáng)制使用索引

  強(qiáng)制使用索引 a 和 b
    db.collection.find ({
        'a ' :   4 ,
        'b ' :   5 ,
        'c ' :   6
    }). hint ({
        'a ' :   1 ,
        'b ' :   1
    });
    強(qiáng)制不使用任何 索引
    db.collection.find ().hint ({
        '$ natural' :   1
    });

索引總結(jié):

  1.     索引可以加速查詢;
  2.     單個(gè)索引無需在意其索引方向;
  3.     多鍵索引需要慎重考慮每個(gè)索引的方向;
  4.     做海量數(shù)據(jù)更新時(shí)應(yīng)當(dāng)先卸載所有索引,待數(shù)據(jù)更新完成后再重建索引;
  5.     不要試圖為每個(gè)鍵都創(chuàng)建索引,應(yīng)考慮實(shí)際需要,并不是索引越多越好;
  6.     唯一索引可以用來消除重復(fù)記錄;
  7.     地理空間索引是沒有單位的,其內(nèi)部實(shí)現(xiàn)是基本的勾股定理算法

相關(guān)文章

  • Ubuntu下安裝mongodb 3.4的詳細(xì)過程

    Ubuntu下安裝mongodb 3.4的詳細(xì)過程

    最近參照mongodb的官方文檔在 Unbuntu Server 16.04上安裝了 Mongodb 3.4,步驟很簡單,就順手翻譯了一下這個(gè)文檔,這個(gè)文檔是講述了 Mongodb 3.4 在 Ubuntu 12.04, 14.04, 16.04 上的安裝步驟。需要的朋友們可以參考借鑒。
    2017-01-01
  • MongoDB中方法limit和skip的使用

    MongoDB中方法limit和skip的使用

    這篇文章主要給大家介紹了關(guān)于MongoDB中方法limit和skip的使用方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • CentOS 安裝 Mogodb的步驟(在線&&離線兩種)

    CentOS 安裝 Mogodb的步驟(在線&&離線兩種)

    這篇文章主要介紹了CentOS 安裝 Mogodb的步驟(在線&&離線兩種),需要的朋友可以參考下
    2017-03-03
  • MongoDB詭異問題之sh.stopBalancer卡住的解決方法

    MongoDB詭異問題之sh.stopBalancer卡住的解決方法

    這篇文章主要給大家介紹了關(guān)于MongoDB詭異問題之sh.stopBalancer卡住解決的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • MongoDB實(shí)現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用

    MongoDB實(shí)現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用

    本文詳細(xì)講解了MongoDB實(shí)現(xiàn)查詢、分頁和排序操作以及游標(biāo)的使用方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • c#操作mongodb插入數(shù)據(jù)效率

    c#操作mongodb插入數(shù)據(jù)效率

    今天小編就為大家分享一篇關(guān)于c#操作mongodb插入數(shù)據(jù)效率,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • 教大家8天學(xué)通MongoDB——第一天 基礎(chǔ)入門篇

    教大家8天學(xué)通MongoDB——第一天 基礎(chǔ)入門篇

    MongoDB是目前非常流行的一種非關(guān)系型數(shù)據(jù)庫(NoSQL),因其操作簡單、完全免費(fèi)、源碼公開等特點(diǎn),受到了IT從業(yè)人員的青睞,并被廣泛部署于實(shí)際的生產(chǎn)環(huán)境中。本文教大家8天學(xué)通MongoDB——第一天 基礎(chǔ)入門篇,感興趣的朋友一起來了解了解吧
    2015-09-09
  • 關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題

    關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題

    這篇文章主要介紹了關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • MongoDB數(shù)據(jù)庫基礎(chǔ)操作總結(jié)

    MongoDB數(shù)據(jù)庫基礎(chǔ)操作總結(jié)

    這篇文章主要介紹了MongoDB數(shù)據(jù)庫基礎(chǔ)操作,結(jié)合實(shí)例形式總結(jié)分析了MongoDB數(shù)據(jù)庫創(chuàng)建、刪除、集合、文檔等基本操作技巧,需要的朋友可以參考下
    2020-06-06
  • 阿里云服務(wù)器安裝mongodb的方法

    阿里云服務(wù)器安裝mongodb的方法

    這篇文章主要介紹了阿里云服務(wù)器安裝mongodb的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-11-11

最新評(píng)論