MongoDB字符串截取和分组统计

查询集合operation_log根据params_str字段中org_name进行汇总统计数据。

// 1
{
    "_id": ObjectId("6257"),
    "params_str": "{'time_begin': '2022-04-21', 'time_end': '2022-04-21', 'org_name': '北京', 'rt_type': 'potential_customer'}"
}

// 2
{
    "_id": ObjectId("6258"),
    "params_str": "{'time_begin': '2022-04-21', 'time_end': '2022-04-21', 'org_name': '北京', 'rt_type': 'potential_customer'}"
}

// 3
{
    "_id": ObjectId("625c"),
    "params_str": "{'time_begin': '2022-04-21', 'time_end': '2022-04-21', 'org_name': '北京', 'rt_type': 'potential_customer'}"
}

params_str字段是一个字符串,非json格式,需要处理。
这里只是简单以“,”号分割数据,做简单的汇总查询。

db.operation_log.aggregate(
    [
				{  "$match": {  //过滤条件取params_str不为空的字段
                "params_str": {$ne: null}}
        }
			,
			{"$project":{  //使用$split对params_str字段进行切割,得到params的json格式
                "params": { "$split": ["$params_str", ","] } }
	}
	,
	  {
        "$project": {
            "params": 1,
            // 然后使用$arrayElemAt获得params数组中第三个元素,命名为org
            "org": {
                "$arrayElemAt": [ "$params",2]
            }
        }
    },
			{"$group":{"_id":"$org",count:{$sum:1}} }

    ]
)

查询结果

{
    "_id": " 'org_name': '北京'",
    "count": 3
}

查询弊端就是如果前面包含了多个逗号,切分出来第3个元素就不是org_name这个字段,导致统计不对,需要确保元素格式是一致的,起码前面格式是一致的。

https://blog.csdn.net/qq330983778/article/details/106698094

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值