Ricardo·M·Smile 2020-03-15 21:27 采纳率: 75%
浏览 209
已采纳

spring mongodb 分组统计 求助?

图片说明
如上图所述:
如何 分组 evaluateItem 然后统计 evaluateLevel 对应 各 等级 数量

  • 写回答

1条回答 默认 最新

  • 憧憬blog 2023-03-15 02:44
    关注

    对于这个问题,我们可以使用 Spring Data MongoDB 中的聚合(Aggregation)功能来进行分组统计。具体代码如下:

    Aggregation agg = Aggregation.newAggregation(
            Aggregation.group("evaluateItem").count().as("count"),
            Aggregation.project("count").and("evaluateItem").previousOperation(),
            Aggregation.sort(Sort.Direction.ASC, "evaluateItem")
    );
    
    AggregationResults<Document> results = mongoTemplate.aggregate(agg, "your_collection_name", Document.class);
    List<Document> evalCounts = results.getMappedResults();
    

    上面的代码中,我们首先定义了一个聚合操作,在其中使用 group 来按照 evaluateItem 进行分组,并使用 count() 来统计每个分组内的文档数量。然后使用 project 来选择输出的字段,最后使用 sort 来进行排序操作。

    最后,我们通过 mongoTemplate 来执行聚合操作,并将结果映射成一个 Document 类型的列表。在列表中,每个 Document 都包含一个 evaluateItem 和相应的数量 count。

    需要注意的是,上述代码中的 "your_collection_name" 需要替换成你的实际集合名称。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 4月11日

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀