整理最近用的Mongo查询语句「建议收藏」

整理最近用的Mongo查询语句「建议收藏」整理最近正在用的多条件查询以及聚合查询的实例,作为文档保留供以后查阅

整理最近用的Mongo查询语句

背景

最近做了几个规则逻辑。用到mongo查询比较多,就是查询交易信息跑既定规则筛选出交易商户,使用聚合管道进行统计和取出简单处理后的数据,用SQL代替业务代码逻辑的判断。

方法

MongoDB聚合使用aggregate,聚合管道采取自动向下子执行方式,基本语法格式:

db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

聚合框架中常用的操作:

  • $project:修改输入文档的结构。可以用来重命名、增加或删除域,也可以用于创建计算结果以及嵌套文档。
  • (match:用于过滤数据,只输出符合条件的文档。)match使用MongoDB的标准查询操作。
  • $limit:用来限制MongoDB聚合管道返回的文档数。
  • $skip:在聚合管道中跳过指定数量的文档,并返回余下的文档。
  • $unwind:将文档中的某一个数组类型字段拆分成多条,每条包含数组中的一个值。
  • $group:将集合中的文档分组,可用于统计结果。
  • $sort:将输入文档排序后输出。
  • $geoNear:输出接近某一地理位置的有序文档。
表达式 描述 实例
$sum 计算总和。 db.mycol.aggregate([{(group : {_id : “)by_user”, num_tutorial : {(sum : “)likes”}}}])
$avg 计算平均值 db.mycol.aggregate([{(group : {_id : “)by_user”, num_tutorial : {(avg : “)likes”}}}])
$min 获取集合中所有文档对应值得最小值。 db.mycol.aggregate([{(group : {_id : “)by_user”, num_tutorial : {(min : “)likes”}}}])
$max 获取集合中所有文档对应值得最大值。 db.mycol.aggregate([{(group : {_id : “)by_user”, num_tutorial : {(max : “)likes”}}}])
$push 在结果文档中插入值到一个数组中。 db.mycol.aggregate([{(group : {_id : “)by_user”, url : {(push: “)url”}}}])
$addToSet 在结果文档中插入值到一个数组中,但不创建副本。 db.mycol.aggregate([{(group : {_id : “)by_user”, url : {(addToSet : “)url”}}}])
$first 根据资源文档的排序获取第一个文档数据。 db.mycol.aggregate([{(group : {_id : “)by_user”, first_url : {(first : “)url”}}}])
$last 根据资源文档的排序获取最后一个文档数据 db.mycol.aggregate([{(group : {_id : “)by_user”, last_url : {(last : “)url”}}}])

查询示例

示例一

部分字段说明:transAmt:交易金额,transType:交易类型,transTime:交易时间,mercNum:商户编号

查询交易信息,交易商户昨天交易笔数大于三百,交易金额累加大于三百万,这里现根据$match将交易信息筛选出来,然后使用$group根据商户编号分组,统计交易笔数和累加交易金额,将分组结果判断匹配交易笔数大于三百,交易金额大于三百万。

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
        }
    }
])

查询结果:

{
    "cardNos" : [ 
        "n2IwHHhfEAJcm6RFsoNPcBVAjW/hWAWj", 
        "n2IwHHhfEAJcm6RFsoNPcBVAjW/hWAWj"
    ]
}

示例四

根据时间查询交易信息后,根据商户号分组,并将第一个交易信息存放入data字段中。(如果是需要全部的商户交易信息那么将$first修改为$push

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
        }
    }
])

尾言

最近那个到查询的大差不差,要注意的都是一些小改动,一般情况正常查就可以。后续有什么不一样的会继续补充。先到这里

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6013.html

(0)
上一篇 2023-04-19
下一篇 2023-04-19

相关推荐

  • MySQL深入学习-

    MySQL深入学习-B+树索引的正确使用 索引并不是越多越好,索引创建越多,MySQL维护的代价越高,如果SQL未能完全使用到索引,创建索引的意义是不大的。 适用条件 表x,创建索引a,b,c。主键y。 全值匹配 sel

    2023-05-18
    153
  • WEB安全入门:如何防止 CSRF 攻击?

    WEB安全入门:如何防止 CSRF 攻击?现在,我们绝大多数人都会在网上购物买东西。但是很多人都不清楚的是,很多电商网站会存在安全漏洞。乌云就通报过,国内很多家公司的网站都存在 CSRF 漏洞。如果某个网站存在这种安全漏洞的话,那么我们在购…

    2023-03-14
    164
  • mariadb修改root密码_ubuntu忘记root密码

    mariadb修改root密码_ubuntu忘记root密码linux中mysql忘记root密码如何登陆 1.关闭mysql服务 systemctl stop mysqld netstat -tunlp|grep mysqld 2.进入配置文件添加一条命令…

    2023-03-30
    677
  • SQL server 系统视图查询「建议收藏」

    SQL server 系统视图查询「建议收藏」– 查询所有表名、字段名、类型、长度 select o.name, c.name,t.name,c.length from syscolumns c inner join systypes t o…

    2023-03-14
    138
  • Python实现Kill进程的方法

    Python实现Kill进程的方法在计算机中,进程是程序在执行时的实例。一个进程可以包含多个线程,在不同的线程中执行不同的代码。在某些情况下,我们需要终止进程,以确保系统资源不被浪费。在Linux和Unix等系统中,通过使用Kill命令可以终止运行的进程。Kill命令可以向特定进程发送一个信号,请求其终止运行。

    2024-08-31
    21
  • oracle的导入导出_oracle表结构导出

    oracle的导入导出_oracle表结构导出第二章 Oracle体系架构和导入/导出 Oracle体系结构 服务名,实例名,orcl n Oracle通过数据库实例来加载和管理数据库,每个运行的Oracle数据库都对应一个Oracle实例(In

    2023-02-05
    163
  • Sql Server Sum函数的特殊使用「建议收藏」

    Sql Server Sum函数的特殊使用「建议收藏」利用Sql Server的Sum函数开窗得到累计值 具体详解https://www.cnblogs.com/zhaoshujie/p/9594676.html 个人示例例子 DECLARE @Sale

    2023-03-09
    153
  • LeetCode Python练习题

    LeetCode Python练习题LeetCode是一个程序员学习、提高算法能力的网站。网站包含了各种难度和类型的编程题目,涉及各种数据结构和算法,并提供在线代码编辑器供用户提交代码测试。通过掌握LeetCode上的编程题目,能够帮助程序员提高算法思维和编程能力。

    2024-07-12
    42

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注