查看: 85|回覆: 0

java mongodb groupby分组查询

[複製鏈接]

4

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2009-7-8
發表於 2019-7-3 16:42:00 | 顯示全部樓層 |閲讀模式
mongodb,聚合查询
命令格式:
db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

示例:db.
COLLECTION_NAME.aggregate(
  [
    { "$match" : { "status" : { "$ne" : 4 } } }
    { "$group" : { "_id" : { "projectTreeName" : "$projectTreeName", "batchName" : "$batchName" } } },
    { "$sort" : { "_id.projectTreeName" : -1 } },
    {$skip:2},
    {$limit:3}
  ])
解读:
  mongodb的聚合查询有个管道的概念,先执行完上一个管道,执行结果流入下一个管道。
  上面这个例子就是:先执行 $match 再进入 $group 进行分组,然后对分组结果进行$sort排序,最后对查询结果进行分页设置。
java
  我使用的是springboot 需要添加mongodb的依赖jar包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
</dependency>

application.properties的配置文件
spring.data.mongodb.uri=mongodb://username:password@localhost:27017/database
配置完成后,可以继承MongoRepository进行基本增删改查操作,这次主要讨论分组查询。
分组查询使用mongotemplate 直接使用@Autowired进行自动装配就行
 
import static org.springframework.data.mongodb.core.aggregation.Aggregation.*;
@Autowired
private MongoTemplate mongoTemplate;
//方法中调用的newAggregation还有match,group,sort等管道函数都是org.springframework.data.mongodb.core.aggregation.Aggregation提供的静态方法
Aggregation agg = newAggregation(
    match(new Criteria("status").ne(4)),
    group("batchName" ,"projectTreeName"),
    sort(new Sort(Sort.Direction.DESC,"projectTreeName")),
    skip(0L),
    limit(10)
  );
AggregationResults<Damweb_ClusterJob_jobs> aggregationResults = mongoTemplate.aggregate(agg,"COLLECTION_NAME", Damweb_ClusterJob_jobs.class);
 


来源:https://www.cnblogs.com/BigWrite/p/11127404.html
回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部