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

MongoDB 管道的介紹及操作符實例

 更新時間:2017年07月31日 15:55:24   投稿:lqh  
這篇文章主要介紹了MongoDB 管道的介紹及操作符實例的相關(guān)資料,MongoDB的聚合管道將MongoDB文檔在一個管道處理完畢后將結(jié)果傳遞給下一個管道處理,需要的朋友可以參考下

MongoDB 管道的介紹及操作符實例

一 介紹

管道在Unix和Linux中一般用于將當前命令的輸出結(jié)果作為下一個命令的參數(shù)。
MongoDB的聚合管道將MongoDB文檔在一個管道處理完畢后將結(jié)果傳遞給下一個管道處理。管道操作是可以重復的。

表達式:處理輸入文檔并輸出。表達式是無狀態(tài)的,只能用于計算當前聚合管道的文檔,不能處理其它的文檔。

這里我們介紹一下聚合框架中常用的幾個操作:

  1. $project:修改輸入文檔的結(jié)構(gòu)。可以用來重命名、增加或刪除域,也可以用于創(chuàng)建計算結(jié)果以及嵌套文檔。
  2. $match:用于過濾數(shù)據(jù),只輸出符合條件的文檔。$match使用MongoDB的標準查詢操作。
  3. $limit:用來限制MongoDB聚合管道返回的文檔數(shù)。
  4. $skip:在聚合管道中跳過指定數(shù)量的文檔,并返回余下的文檔。
  5. $unwind:將文檔中的某一個數(shù)組類型字段拆分成多條,每條包含數(shù)組中的一個值。
  6. $group:將集合中的文檔分組,可用于統(tǒng)計結(jié)果。
  7. $sort:將輸入文檔排序后輸出。
  8. $geoNear:輸出接近某一地理位置的有序文檔。 

二 管道操作符實例

1、$project實例

db.article.aggregate(
  { $project : {
    title : 1 ,
    author : 1 ,
  }}
 );

這樣的話結(jié)果中就只還有_id,tilte和author三個字段了,默認情況下_id字段是被包含的,如果要想不包含_id話可以這樣:

db.article.aggregate(
  { $project : {
    _id : 0 ,
    title : 1 ,
    author : 1
  }});

2.$match實例

db.articles.aggregate( [
            { $match : { score : { $gt : 70, $lte : 90 } } },
            { $group: { _id: null, count: { $sum: 1 } } }
            ] );

$match用于獲取分數(shù)大于70小于或等于90記錄,然后將符合條件的記錄送到下一階段$group管道操作符進行處理。

3.$skip實例

db.article.aggregate(
  { $skip : 5 });

經(jīng)過$skip管道操作符處理后,前五個文檔被"過濾"掉。

如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

最新評論