在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
背景最近做了几个规则逻辑。用到mongo查询比较多,就是查询交易信息跑既定规则筛选出交易商户,使用聚合管道进行统计和取出简单处理后的数据,用SQL代替业务代码逻辑的判断。 方法MongoDB聚合使用 db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION) 聚合框架中常用的操作:
查询示例示例一部分字段说明:transAmt:交易金额,transType:交易类型,transTime:交易时间,mercNum:商户编号 查询交易信息,交易商户昨天交易笔数大于三百,交易金额累加大于三百万,这里现根据 db.getCollection('box_order').aggregate([ { $match: { "transTime":{$gte:ISODate("2020-01-03T00:00:00.000Z"),$lt:ISODate("2020-01-10T00:00:00.000Z")}, "transType":"consume", "transStatus":{$in:["tsProcessing","success"]} } }, { $group: { "_id": "$mercNum", "count": {"$sum": 1}, "totalAmt": {"$sum": "$transAmt"} } }, { $match: { "count": {"$gte": 300}, "totalAmt": {"$gte": 3000000} } } ]) 示例二部分字段说明:cardNo:交易卡号,transType:交易类型,transTime:交易时间,mercNum:商户编号 查询时间段内指定卡号下的交易商户信息。 根据卡号和交易时间将交易数据查出来,然后只显示商户号和卡号两列字段,根据商户号和卡号分组去重,再根据卡号分组,将商户号转化成一个字段变成数组。 db.getCollection('order_202011').aggregate([ { "$match": { "detailInfo.cardNo": { "$in": [ "YtCZ7KhCVG5xerKUg8bzJhVAjW/hWAWj", "cQ7QQ0yCVW6LhHtJNVRq2A==", "6KDpHmQ9s+0SQAGAUyLJ4A==", "cQ7QQ0yCVW7iSegn8uqIfg==", "ZEOcXdI4rfvswAz7dQ80hw==", "6KDpHmQ9s+2Nz61PPuOamw==" ] }, "baseInfo.transTime": { "$gte": new Date(2020,10,01), "$lt": new Date(2020,10,24) } } }, { "$project": { "merchantInfo.mercNum": 1, "detailInfo.cardNo": 1 } }, { "$group": { "_id": { "mercNum": "$merchantInfo.mercNum", "cardNo": "$detailInfo.cardNo" } } }, { "$group": { "_id": "$_id.cardNo", "mercNums": { "$push": "$_id.mercNum" } } } ]) 示例三根据指定商户和其他条件查询交易信息,根据卡号分组并组装成一个字段的集合,最后筛选掉id只保留cardNos数组 db.getCollection('box_order_fxq_202104').aggregate([ { "$match": { "mercNum": "M15201812030753174730", "transTime": { "$gte": ISODate("2021-04-17T16:00:00.000Z"), "$lt": ISODate("2021-04-18T16:00:00.000Z") }, "mercLevel": { "$in": [ "C", "D", "E" ] }, "payType": "POSPAY", "transType": "consume", "cardType": "2" } }, { "$group": { "_id": null, "cardNos": { "$push": "$cardNo" //$addToSet } } }, { "$project":{ "cardNos":1,"_id":0 } } ]) 查询结果:
示例四根据时间查询交易信息后,根据商户号分组,并将第一个交易信息存放入data字段中。(如果是需要全部的商户交易信息那么将 db.getCollection('order').aggregate([ { "$match": { "startTrxTime": { "$gte": ISODate("2021-07-20T16:00:00.000Z"), "$lt": ISODate("2021-07-21T16:00:00.000Z") } } }, { "$group": { "_id": "$subMerchantNo", 'data':{'$first': '$$ROOT'} //$push } }, { "$sort": { "_id": 1 } } ]) 尾言最近那个到查询的大差不差,要注意的都是一些小改动,一般情况正常查就可以。后续有什么不一样的会继续补充。先到这里 到此这篇关于整理最近用的MongoDB查询语句的文章就介绍到这了,更多相关Mongo查询语句内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界! |
请发表评论