• mongo 过滤查询条件后分组、排序


    描述:最近业主有这么一个需求,根据集合中 时间段进行过滤,过滤的时间时间段为日期类型字符串,需要根据某一日期进行截取后。进行分组,排序

    概述题目:根据createTime时间段做查询,然后以 天进行分组,对分组后的结构排序

    1、集合信息如下(集合名称为 :DBDH) :

    {
        "_id" : "123456789",
        "createTime" : "20180815155266",
        "infoPath" : "E:\dbdh\pic\20180818\1000999\100987\18\15L\",
        "receiveTime" : "20180815155288",
        "centerNo" : "10001001"
    }

    2、执行语句为

      db.DBDH.aggregate(

        {
            $match: {/ *匹配条件*/
                createTime: { $gte: "20180815155266", $lte: "20181010155266" }
            }
        }  ,
        {  
            $project :{new_time :{$substr :["$createTime",10,2]},"_id":0,createTime:1,}      /* 从第十个位置截取长度为2位*/
        }   ,
        {  
            $group : {/ *分组*/
                 _id :"$new_time",  count: { $sum: 1}
        
             }  
        }  ,
        {
            $sort: {"_id": 1}  / *排序 */
         }
    )

    执行结果(执行结果说明有两条记录既:count=2,截取后的值都为: 52):

    /* 1 */
    {
        "_id" : "52",
        "count" : 2.0
    }

  • 相关阅读:
    对拍
    311随笔
    精彩才刚刚开始
    做不下去了,就开心一下吧。
    情书
    论Sue这个人呐(=@__@=)
    P1113 杂务
    P1546 最短网络 Agri-Net
    P2009 跑步
    P2814 家谱
  • 原文地址:https://www.cnblogs.com/northeastTycoon/p/10558756.html
Copyright © 2020-2023  润新知