亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MongoDB 管道的介紹及操作符實(shí)例

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

MongoDB 管道的介紹及操作符實(shí)例

一 介紹

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

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

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

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

二 管道操作符實(shí)例

1、$project實(shí)例

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

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

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

2.$match實(shí)例

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

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

3.$skip實(shí)例

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

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

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

相關(guān)文章

最新評(píng)論