MongoDb 分组统计查询

javascript 复制代码
db.getCollection("CommonStatisticsLog").aggregate([
    {
        "$match": {
            "CreateTime": {
                "$gte": ISODate("2025-02-13T09:00:00Z"),
                "$lte": ISODate("2025-02-13T09:59:59Z")
            },
            "NeedStatisticsHourLog": true
        }
    },
    {
        "$group": {
            "_id": {
                "ProductKey": "$ProductKey",
                "DeviceName": "$DeviceName",
                "LogType": "$LogType",
                "StatisticsType": "$StatisticsType"
            },
            "TotalTimes": { "$sum": "$Times" },
            "TotalSeconds": { "$sum": "$Seconds" }
        }
    },
    {
        "$project": {
            "_id": 0,
            "ProductKey": "$_id.ProductKey",
            "DeviceName": "$_id.DeviceName",
            "LogType": "$_id.LogType",
            "StatisticsType": "$_id.StatisticsType",
            "DateCode": 2025021309,
            "TotalTimes": "$TotalTimes",
            "TotalSeconds": "$TotalSeconds"
        }
    },
    {
        "$sort": { "CreateTime": -1 }
    },
    {
        "$skip": 0
    },
    {
        "$limit": 1
    }
])
解释:

1、aggregate : 开启一个聚合查询;里面包含多个管道列表用 [ ] 包住;

每个管道用 {} 包裹;

2、$match:条件查询,只能出现一次,每个条件用 { }包裹;
javascript 复制代码
 "$match": {
            "CreateTime": {
                "$gte": ISODate("2025-02-13T09:00:00Z"),
                "$lte": ISODate("2025-02-13T09:59:59Z")
            },
            "NeedStatisticsHourLog": true
        }
3、$group : 按属性分组
4、$project : 输出字段
5、$sort : 排序
6、$skip : 第几个开始取数据;
7、$limit :取几条数据
相关推荐
JIngJaneIL30 分钟前
基于java + vue个人博客系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
TG:@yunlaoda360 云老大39 分钟前
华为云国际站代理商备份策略设置过程中遇到问题如何解决?
服务器·数据库·华为云
SelectDB1 小时前
Doris Catalog 已上线!性能提升 200x,全面优于 JDBC Catalog,跨集群查询迈入高性能分析时代
数据库·数据分析·apache
TAEHENGV1 小时前
进度跟踪模块 Cordova 与 OpenHarmony 混合开发实战
android·javascript·数据库
神秘面具男031 小时前
MySQL 从基础到实践
数据库·mysql
2301_767902643 小时前
MySQL 入门
数据库·mysql
7ioik3 小时前
说一说MySQL数据库基本架构?
数据库·mysql·架构
@淡 定3 小时前
Redis持久化机制
数据库·redis·缓存
云老大TG:@yunlaoda3603 小时前
华为云国际站代理商DAS的跨境合规适配是如何保障数据合规的?
网络·数据库·华为云
TG:@yunlaoda360 云老大3 小时前
华为云国际站代理商HiLens的技术优势对跨境客户有哪些具体帮助?
服务器·数据库·华为云