一、概述

1. 聚合的表达式

MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果。有点类似sql语句中的 count(*)。

下表展示了一些聚合的表达式:

表达式 描述 实例
$sum 计算总和。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$sum : "$likes"}}}])
$avg 计算平均值 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$avg : "$likes"}}}])
$min 获取集合中所有文档对应值得最小值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$min : "$likes"}}}])
$max 获取集合中所有文档对应值得最大值。 db.mycol.aggregate([{$group : {_id : "$by_user", num_tutorial : {$max : "$likes"}}}])
$push 在结果文档中插入值到一个数组中。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$push: "$url"}}}])
$addToSet 在结果文档中插入值到一个数组中,但不创建副本。 db.mycol.aggregate([{$group : {_id : "$by_user", url : {$addToSet : "$url"}}}])
$first 根据资源文档的排序获取第一个文档数据。 db.mycol.aggregate([{$group : {_id : "$by_user", first_url : {$first : "$url"}}}])
$last 根据资源文档的排序获取最后一个文档数据 db.mycol.aggregate([{$group : {_id : "$by_user", last_url : {$last : "$url"}}}])

2. 管道的概念

管道在Unix和Linux中一般用于将当前命令的输出结果作为下一个命令的参数。

MongoDB的聚合管道将MongoDB文档在一个管道处理完毕后将结果传递给下一个管道处理。管道操作是可以重复的。

表达式:处理输入文档并输出。表达式是无状态的,只能用于计算当前聚合管道的文档,不能处理其它的文档。

这里我们介绍一下聚合框架中常用的几个操作:

  • $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。
  • $match:用于过滤数据,只输出符合条件的文档。$match使用MongoDB的标准查询操作。
  • $limit:用来限制MongoDB聚合管道返回的文档数。
  • $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
  • $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
  • $group:将集合中的文档分组,可用于统计结果。
  • $sort:将输入文档排序后输出。
  • $geoNear:输出接近某一地理位置的有序文档。

3. 聚合查询示例:

1

2

3

4

db.articles.aggregate( [

                        { $match : { score : { $gt : 70, $lte : 90 } } },

                        { $group: { _id: null, count: { $sum: 1 } } }

                       ] );

但是在代码中要如何实现类似以上功能呢?

二、代码实现(sum求和)

功能描述:

  1. 当name和course同时传参时,按id分组,统计总分数
  2. 按name分组,统计相同name的总分数
  3. 按course分组,统计总分数

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

public double getTotleScoreWithMongoTemplate(StudentScore studentScore) {

  //封装查询条件

  List<AggregationOperation> operations = new ArrayList<>();

  if (StringUtils.isEmpty(studentScore.getName()) && StringUtils.isEmpty(studentScore.getCourse())){

    //totleScore为StudentScore类中新建的属性,用于接收统计后的总分数;当然也可以使用score(或其他属性)接收

    operations.add(Aggregation.group("id").sum("score").as("totleScore"));

  }

  if (!StringUtils.isEmpty(studentScore.getName())) {

    operations.add(Aggregation.match(Criteria.where("name").is(studentScore.getName())));

    operations.add(Aggregation.group("name").sum("score").as("totleScore"));

  }

  if (!StringUtils.isEmpty(studentScore.getCourse())) {

    operations.add(Aggregation.match(Criteria.where("course").is(studentScore.getCourse())));

    operations.add(Aggregation.group("course").sum("score").as("totleScore"));

  }

  Aggregation aggregation = Aggregation.newAggregation(operations);

  //查询、并获取结果

  AggregationResults<StudentScore> results = mongoTemplate.aggregate(aggregation, "studentScore", StudentScore.class);

  double totleScore = results.getUniqueMappedResult().getTotleScore();

  return totleScore;

}

MongoTemplate 聚合查询相关推荐

  1. mongotemplate 查list_mongoTemplate.aggregate()聚合查询 时间

    一.概述 1. 聚合的表达式 MongoDB中聚合(aggregate)主要用于处理数据(诸如统计平均值,求和等),并返回计算后的数据结果.有点类似sql语句中的 count(*). 下表展示了一些聚 ...

  2. MongoTemplate 使用aggregate聚合查询

    db.getCollection('trade').aggregate([ // $match 在$group 前过滤分组前数据 $match在$group之后过滤分组后的文档{ $match : { ...

  3. SpringBoot之MongoTemplate的查询可以怎么耍

    学习一个新的数据库,一般怎么下手呢?基本的CURD没跑了,当可以熟练的增.删.改.查一个数据库时,可以说对这个数据库算是入门了,如果需要更进一步的话,就需要了解下数据库的特性,比如索引.事物.锁.分布 ...

  4. mongo java aggregate_java使用spring + mongo进行Aggregation聚合查询

    笔记:使用mongo聚合查询(一开始根本没接触过mongo,一点一点慢慢的查资料完成了工作需求) 需求:在订单表中,根据buyerNick分组,统计每个buyerNick的电话.地址.支付总金额以及总 ...

  5. Mongodb使用之Aggregation聚合查询:.group()/.project()/.and().previousOperation()等api的使用

    最近在项目中遇到了Mongodb在聚合查询上的应用,在这里做一个记录. Spring Data MongoDB 中的聚合框架支持基于以下关键抽象:Aggregation.AggregationDefi ...

  6. MongoDB的使用学习之(七)MongoDB的聚合查询(spring-data-mongodb两种方式)附项目源码

    虽然只看了这一篇文章,但应该这个系列的文件应该都不错. http://www.cnblogs.com/ontheroad_lee/p/3756247.html 铛铛铛--项目源码下载地址:http:/ ...

  7. Java操作Mongodb数据(增删改查聚合查询)

    文章目录 一.Java操作MongoDB 二.使用步骤 1.基础配置 2.实体类 3.MongoDB表数据 3.增删改查聚合查询 总结 一.Java操作MongoDB 上一篇文章介绍了,如何在本地使用 ...

  8. java操作es聚合操作并显示其他字段_java使用elasticsearch分组进行聚合查询过程解析...

    这篇文章主要介绍了java使用elasticsearch分组进行聚合查询过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 java连接elas ...

  9. es的聚合mysql聚合速度_Elasticsearch(8) --- 聚合查询(Metric聚合)

    摘要: quot;:0,"aggs":{"stats_salary":{"stats":{"field":"s ...

最新文章

  1. c# yield关键字原理
  2. git 拉取远程分支及修改远程仓库地址
  3. CentOS安装Java JDK
  4. 论文阅读:Network In Network
  5. OpenCV场景文本识别的实例(附完整代码)
  6. Activity的常用方法和生命周期
  7. Python 100例(上)
  8. Android Studio --- [学习笔记]Button、TextView、EditText
  9. 动态规划训练24 [Phalanx HDU - 2859 ]
  10. 小程序 循环中有多个input,怎么获取每个input输入框的值
  11. 属于程序员的等级,看看你是哪个级别?
  12. matplotlib tricks(一)—— 多类别数据的 scatter(cmap)
  13. ERROR:STATUS_BROM_CMD_SEND_DA_FALL(0xC0060003)
  14. liunx版pgadmin3 source code安装
  15. Git版本控制管理教程(一):介绍
  16. 小米手机与计算机如何连接网络连接,小米手机如何连接电脑?如何传输文件至电脑?...
  17. 路由器忘记密码的解决办法
  18. 西游记中孙悟空被唐僧赶走的三回
  19. 预防抑郁的简单技巧:每周快走2.5小时
  20. 曙光服务器amd芯片,AMD六核体验 曙光Ar-H服务器首发评测.docx

热门文章

  1. 微信公众号排版的使用
  2. html写出带有表格标题的三行三列表格
  3. 全景制作平台,krpano全景图下载并快速关联漫游
  4. WSUS管理控制台打开报错
  5. 使用Jupyter Notebook远程连接服务器
  6. Bmob后端云初体验
  7. 陀螺年度巨献 | 2020年度区块链产业发展报告
  8. MacOS系统下 adb 调试电视相关(homebrew安装 adb)
  9. 使用 html2canvas 生成图片
  10. git 从当前分支copy出新分支