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 :取几条数据
相关推荐
数据知道5 分钟前
PostgreSQL 故障排查:万字详解如何找出数据库中的死锁
数据库·postgresql
AI_567813 分钟前
阿里云OSS成本优化:生命周期规则+分层存储省70%
运维·数据库·人工智能·ai
choke23316 分钟前
软件测试任务测试
服务器·数据库·sqlserver
龙山云仓17 分钟前
MES系统超融合架构
大数据·数据库·人工智能·sql·机器学习·架构·全文检索
IT邦德18 分钟前
OEL9.7 安装 Oracle 26ai RAC
数据库·oracle
jianghua00136 分钟前
Django视图与URLs路由详解
数据库·django·sqlite
那我掉的头发算什么37 分钟前
【Mybatis】Mybatis-plus使用介绍
服务器·数据库·后端·spring·mybatis
倔强的石头10638 分钟前
关系数据库替换用金仓:数据迁移过程中的完整性与一致性风险
数据库·kingbase
_Johnny_39 分钟前
ETCD 配额/空间告警模拟脚本
数据库·chrome·etcd
静听山水42 分钟前
StarRocks查询加速
数据库