mongoDB進行分組操作

來源:互聯網
上載者:User

標籤:tco   job   _id   set   count   push   mongo   data   操作   

一、$group 進行分組

1、每個職位的僱員人數:

db.getCollection(‘emp‘).aggregate(

   [

     {‘$group‘:{

           ‘_id’:‘$job‘,

           job_count:{‘$sum‘:1}

    }

         }

   ]

)

2、每個職位的總工資

db.getCollection(‘emp‘).aggregate(

   [

     {‘$group‘:{

           ‘_id’:‘$job‘,

           job_salaryt:{‘$sum‘:‘$salary‘}

    }

         }

   ]

)

3、每個職位的平均工資

db.getCollection(‘emp‘).aggregate(

   [

        {‘$group‘:{

                  ‘_id’:‘$job‘,

                  job_salaryt:{‘$sum‘:‘$salary‘},

                  job_salary_avg:{‘$avg‘:‘$salary‘}

                   }

             }

   ]

)

4、每種職位的最高與最低工資

db.getCollection(‘emp‘).aggregate(

   [

        {‘$group‘:{

                  ‘_id’:‘$job‘,

                 max_salaryt:{‘$max‘:‘$salary‘},

                  min_salary:{‘$min‘:‘$salary‘}

                   }

             }

   ]

)

5、每個職位的工資

db.getCollection(‘emp‘).aggregate(

    [

       {

         ‘$group’:{

                 ‘_id‘:‘$job‘,

               ‘salary_data‘:{‘$push‘:‘$salary‘}

         }

       }

   ]

)

6、每個職位的人員

db.getCollection(‘emp‘).aggregate(

    [

       {

         ‘$group’:{

                 ‘_id‘:‘$job‘,

               ‘position_name‘:{‘$addToSet‘:‘$name‘}  //addToSet,如果有重複的人名,保留一個

         }

       }

   ]

)

二、$project 進行資料的規則顯示

1、別名

db.getCollection(‘emp‘).aggregate(

[

   {‘$project‘:{

        ‘_id‘:0

       ‘職位‘:‘$job‘,

       ‘name‘:1

           }

   }

]

)

2、年薪

db.getCollection(‘emp‘).aggregate(

[

     {

           ‘$project‘:{

              ‘name‘:1,

               ‘salary‘:{‘年薪‘:{‘$multiply‘:[‘$salary‘,12]}}

            }

     }

]

)

mongoDB進行分組操作

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.