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 :取几条数据
相关推荐
一个天蝎座 白勺 程序猿1 小时前
Apache IoTDB(5):深度解析时序数据库 IoTDB 在 AINode 模式单机和集群的部署与实践
数据库·apache·时序数据库·iotdb·ainode
QQ3596773451 小时前
ArcGIS Pro实现基于 Excel 表格批量创建标准地理数据库(GDB)——高效数据库建库解决方案
数据库·arcgis·excel
学编程的小程2 小时前
突破局域网限制:MongoDB远程管理新体验
数据库·mongodb
波波烤鸭2 小时前
Redis 高可用实战源码解析(Sentinel + Cluster 整合应用)
数据库·redis·sentinel
l1t6 小时前
利用DeepSeek实现服务器客户端模式的DuckDB原型
服务器·c语言·数据库·人工智能·postgresql·协议·duckdb
MarkHard12310 小时前
如何利用redis使用一个滑动窗口限流
数据库·redis·缓存
清风66666611 小时前
基于STM32的APP遥控视频水泵小车设计
stm32·单片机·mongodb·毕业设计·音视频·课程设计
island131411 小时前
【Redis#10】渐进式遍历 | 数据库管理 | redis_cli | RES
数据库·redis·bootstrap
心想事成的幸运大王11 小时前
Redis的过期策略
数据库·redis·缓存
倔强的石头_11 小时前
CentOS 上安装KingbaseES(ISO包)详细教程
数据库