濮阳杆衣贸易有限公司

主頁 > 知識(shí)庫 > 常用的MongoDB查詢語句的示例代碼

常用的MongoDB查詢語句的示例代碼

熱門標(biāo)簽:內(nèi)蒙古營銷智能外呼系統(tǒng)哪個(gè)好 青白江400企業(yè)電話申請(qǐng) 小裙科技電銷機(jī)器人怎樣 crm外呼系統(tǒng)聯(lián)系方式 呼和浩特外呼系統(tǒng)原理是什么 外呼線路資源屬于電信業(yè)務(wù)嗎 長沙電銷外呼防封卡是什么 智能外呼系統(tǒng)官網(wǎng) 河南電話外呼系統(tǒng)招商

背景

最近做了幾個(gè)規(guī)則邏輯。用到mongo查詢比較多,就是查詢交易信息跑既定規(guī)則篩選出交易商戶,使用聚合管道進(jìn)行統(tǒng)計(jì)和取出簡單處理后的數(shù)據(jù),用SQL代替業(yè)務(wù)代碼邏輯的判斷。

方法

MongoDB聚合使用aggregate,聚合管道采取自動(dòng)向下子執(zhí)行方式,基本語法格式:

db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

聚合框架中常用的操作:

  • $project:修改輸入文檔的結(jié)構(gòu)??梢杂脕碇孛?、增加或刪除域,也可以用于創(chuàng)建計(jì)算結(jié)果以及嵌套文檔。
  • match:用于過濾數(shù)據(jù),只輸出符合條件的文檔。match:用于過濾數(shù)據(jù),只輸出符合條件的文檔。match使用MongoDB的標(biāo)準(zhǔn)查詢操作。
  • $limit:用來限制MongoDB聚合管道返回的文檔數(shù)。
  • $skip:在聚合管道中跳過指定數(shù)量的文檔,并返回余下的文檔。
  • $unwind:將文檔中的某一個(gè)數(shù)組類型字段拆分成多條,每條包含數(shù)組中的一個(gè)值。
  • $group:將集合中的文檔分組,可用于統(tǒng)計(jì)結(jié)果。
  • $sort:將輸入文檔排序后輸出。
  • $geoNear:輸出接近某一地理位置的有序文檔。

表達(dá)式 描述 實(shí)例
$sum 計(jì)算總和。 db.mycol.aggregate([{\(group : {_id : "\)by_user", num_tutorial : {likes"}}}])
$avg 計(jì)算平均值 db.mycol.aggregate([{\(group : {_id : "\)by_user", num_tutorial : {likes"}}}])
$min 獲取集合中所有文檔對(duì)應(yīng)值得最小值。 db.mycol.aggregate([{\(group : {_id : "\)by_user", num_tutorial : {likes"}}}])
$max 獲取集合中所有文檔對(duì)應(yīng)值得最大值。 db.mycol.aggregate([{\(group : {_id : "\)by_user", num_tutorial : {likes"}}}])
$push 在結(jié)果文檔中插入值到一個(gè)數(shù)組中。 db.mycol.aggregate([{\(group : {_id : "\)by_user", url : {url"}}}])
$addToSet 在結(jié)果文檔中插入值到一個(gè)數(shù)組中,但不創(chuàng)建副本。 db.mycol.aggregate([{\(group : {_id : "\)by_user", url : {url"}}}])
$first 根據(jù)資源文檔的排序獲取第一個(gè)文檔數(shù)據(jù)。 db.mycol.aggregate([{\(group : {_id : "\)by_user", first_url : {url"}}}])
$last 根據(jù)資源文檔的排序獲取最后一個(gè)文檔數(shù)據(jù) db.mycol.aggregate([{\(group : {_id : "\)by_user", last_url : {url"}}}])

查詢示例

示例一

部分字段說明:transAmt:交易金額,transType:交易類型,transTime:交易時(shí)間,mercNum:商戶編號(hào)

查詢交易信息,交易商戶昨天交易筆數(shù)大于三百,交易金額累加大于三百萬,這里現(xiàn)根據(jù)$match將交易信息篩選出來,然后使用$group根據(jù)商戶編號(hào)分組,統(tǒng)計(jì)交易筆數(shù)和累加交易金額,將分組結(jié)果判斷匹配交易筆數(shù)大于三百,交易金額大于三百萬。

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:交易卡號(hào),transType:交易類型,transTime:交易時(shí)間,mercNum:商戶編號(hào)

查詢時(shí)間段內(nèi)指定卡號(hào)下的交易商戶信息。

根據(jù)卡號(hào)和交易時(shí)間將交易數(shù)據(jù)查出來,然后只顯示商戶號(hào)和卡號(hào)兩列字段,根據(jù)商戶號(hào)和卡號(hào)分組去重,再根據(jù)卡號(hào)分組,將商戶號(hào)轉(zhuǎn)化成一個(gè)字段變成數(shù)組。

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

示例三

根據(jù)指定商戶和其他條件查詢交易信息,根據(jù)卡號(hào)分組并組裝成一個(gè)字段的集合,最后篩選掉id只保留cardNos數(shù)組

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

查詢結(jié)果:

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

示例四

根據(jù)時(shí)間查詢交易信息后,根據(jù)商戶號(hào)分組,并將第一個(gè)交易信息存放入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
        }
    }
])

尾言

最近那個(gè)到查詢的大差不差,要注意的都是一些小改動(dòng),一般情況正常查就可以。后續(xù)有什么不一樣的會(huì)繼續(xù)補(bǔ)充。先到這里

到此這篇關(guān)于整理最近用的MongoDB查詢語句的文章就介紹到這了,更多相關(guān)Mongo查詢語句內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • springboot實(shí)現(xiàn)將自定義日志格式存儲(chǔ)到mongodb中
  • mongodb中oplog介紹和格式詳析
  • SpringBoot整合之SpringBoot整合MongoDB的詳細(xì)步驟
  • MongoDB安裝使用并實(shí)現(xiàn)Python操作數(shù)據(jù)庫
  • 淺析MongoDB之安全認(rèn)證
  • SpringBoot整合MongoDB的實(shí)現(xiàn)步驟
  • 詳解MongoDB的條件查詢和排序
  • mongodb的安裝和開機(jī)自啟動(dòng)詳細(xì)講解

標(biāo)簽:安順 池州 菏澤 呼倫貝爾 黃石 楚雄 舟山 白山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《常用的MongoDB查詢語句的示例代碼》,本文關(guān)鍵詞  常用的,常,用的,MongoDB,查詢,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《常用的MongoDB查詢語句的示例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于常用的MongoDB查詢語句的示例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    视频| 山西省| 雅江县| 驻马店市| 甘德县| 昌黎县| 广灵县| 尉犁县| 黄浦区| 肥城市| 芜湖市| 乐都县| 沙田区| 漳州市| 广河县| 闽清县| 渝中区| 灵宝市| 唐海县| 商水县| 张北县| 启东市| 桑植县| 甘洛县| 廊坊市| 万安县| 安吉县| 义乌市| 固阳县| 瑞安市| 嵊州市| 徐汇区| 乌拉特中旗| 会同县| 印江| 资阳市| 安阳市| 高陵县| 芮城县| 新邵县| 鄯善县|