婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

背景

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

方法

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

db.COLLECTION_NAME.aggregate(AGGREGATE_OPERATION)

聚合框架中常用的操作:

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

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

查詢示例

示例一

部分字段說明:transAmt:交易金額,transType:交易類型,transTime:交易時間,mercNum:商戶編號

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

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

尾言

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

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

您可能感興趣的文章:
  • springboot實現將自定義日志格式存儲到mongodb中
  • mongodb中oplog介紹和格式詳析
  • SpringBoot整合之SpringBoot整合MongoDB的詳細步驟
  • MongoDB安裝使用并實現Python操作數據庫
  • 淺析MongoDB之安全認證
  • SpringBoot整合MongoDB的實現步驟
  • 詳解MongoDB的條件查詢和排序
  • mongodb的安裝和開機自啟動詳細講解

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

巨人網絡通訊聲明:本文標題《常用的MongoDB查詢語句的示例代碼》,本文關鍵詞  常用的,常,用的,MongoDB,查詢,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《常用的MongoDB查詢語句的示例代碼》相關的同類信息!
  • 本頁收集關于常用的MongoDB查詢語句的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美性极品少妇| 三级不卡在线观看| 亚洲精品久久嫩草网站秘色| 亚洲一区免费在线观看| 日韩经典中文字幕一区| 国产成人日日夜夜| 99久久精品国产精品久久| 欧美亚洲国产怡红院影院| 日韩午夜精品电影| 中文字幕中文乱码欧美一区二区| 亚洲成av人综合在线观看| 国产在线精品一区二区不卡了| 成人黄色在线看| 欧美日韩国产免费一区二区| 久久奇米777| 亚洲国产精品久久艾草纯爱| 国产剧情一区二区| 欧美在线小视频| 久久精品网站免费观看| 亚洲成人av中文| 国产aⅴ综合色| 欧美日韩极品在线观看一区| 久久精品一区二区三区四区| 一区二区成人在线观看| 国产美女在线观看一区| 欧美在线免费播放| www国产精品av| 亚洲狠狠爱一区二区三区| 国产99久久精品| 成人在线一区二区三区| 日韩一区二区三区电影在线观看| 国产精品久久久久影视| 另类人妖一区二区av| 欧美手机在线视频| 亚洲欧洲日韩在线| 久久 天天综合| 欧美日韩国产综合一区二区| 中文字幕av一区二区三区| 日本一不卡视频| 色婷婷综合激情| 国产精品丝袜久久久久久app| 日日摸夜夜添夜夜添亚洲女人| 91在线免费播放| 欧美国产一区二区在线观看| 精品亚洲免费视频| 6080yy午夜一二三区久久| 亚洲男人的天堂在线观看| 成人激情小说乱人伦| 久久久久久久电影| 麻豆精品视频在线| 欧美精品123区| 亚洲综合小说图片| 91论坛在线播放| 1000部国产精品成人观看| 国产成人精品影视| 精品国产露脸精彩对白| 免费欧美高清视频| 51精品久久久久久久蜜臀| 亚洲国产成人tv| 欧美色综合久久| 亚洲综合精品自拍| 欧美综合一区二区| 一卡二卡三卡日韩欧美| 色香色香欲天天天影视综合网| 亚洲视频 欧洲视频| 成人高清在线视频| 国产精品伦一区二区三级视频| 高清日韩电视剧大全免费| 国产日韩欧美综合一区| 国产精品综合网| 中文字幕成人av| 99久久99久久精品免费看蜜桃| 国产精品国产三级国产aⅴ原创| 成人性色生活片| 国产精品日韩成人| 99免费精品在线观看| 国产精品不卡一区二区三区| 色综合天天做天天爱| 亚洲精品中文在线观看| 91久久精品一区二区三区| 一区二区三区四区高清精品免费观看 | 久久精品国产亚洲高清剧情介绍| 欧美日韩国产一区二区三区地区| 亚洲高清免费观看高清完整版在线观看| 色成年激情久久综合| 亚洲午夜三级在线| 91精品国产综合久久精品性色| 看片的网站亚洲| 国产午夜精品一区二区三区四区| 成人综合日日夜夜| 亚洲卡通欧美制服中文| 7777精品伊人久久久大香线蕉经典版下载 | 成人97人人超碰人人99| 亚洲私人影院在线观看| 欧美日韩综合不卡| 免费成人av资源网| 国产欧美日韩一区二区三区在线观看| 岛国一区二区在线观看| 亚洲自拍偷拍综合| 日韩天堂在线观看| 成人动漫中文字幕| 亚洲一区二区av在线| 日韩欧美国产不卡| 国产ts人妖一区二区| 亚洲午夜私人影院| 欧美tk丨vk视频| 91丨国产丨九色丨pron| 天天色 色综合| 欧美大片日本大片免费观看| 成人黄色av电影| 视频在线观看91| 欧美国产精品v| 欧美影院一区二区三区| 精品亚洲成av人在线观看| 亚洲欧美日韩在线| 日韩欧美卡一卡二| 99在线视频精品| 青青草国产精品亚洲专区无| 亚洲国产精品av| 91麻豆精品国产91久久久久| 成人午夜免费电影| 天天亚洲美女在线视频| 日本一区二区三区免费乱视频| 一本大道久久a久久精品综合| 免费av网站大全久久| 中文字幕一区二| 欧美成人一区二区三区片免费| 91网址在线看| 久久精品72免费观看| 亚洲另类在线视频| 久久精品视频免费| 欧美一区午夜精品| 日本精品一区二区三区四区的功能| 美女视频免费一区| 一区二区三区蜜桃网| 国产偷v国产偷v亚洲高清| 欧美精品久久天天躁| 99精品视频在线观看免费| 精品一区二区三区在线观看| 一区二区三区久久久| 国产亚洲精品资源在线26u| 欧美三级蜜桃2在线观看| av成人老司机| 国产激情一区二区三区桃花岛亚洲| 五月天欧美精品| 亚洲免费观看高清完整版在线观看熊| 精品国产乱码久久久久久久| 欧美年轻男男videosbes| 9i看片成人免费高清| 激情久久五月天| 日本欧美久久久久免费播放网| 国产999精品久久久久久| 久久精品国产免费| 午夜久久久久久久久| 亚洲免费色视频| 专区另类欧美日韩| 欧美精品一区二区三区蜜臀| 91精品国产综合久久婷婷香蕉 | 亚洲一区二区影院| 国产精品传媒视频| 日本一二三不卡| 国产欧美日韩久久| 久久伊99综合婷婷久久伊| 91麻豆精品国产91久久久久久久久 | 国产欧美日韩综合| 久久只精品国产| www国产精品av| 久久在线观看免费| 欧美电影免费观看高清完整版 | 国产综合久久久久久鬼色| 蜜臀a∨国产成人精品| 日韩—二三区免费观看av| 五月激情六月综合| 午夜精品一区在线观看| 亚洲一二三区视频在线观看| 亚洲尤物视频在线| 亚洲国产三级在线| 亚洲成人在线网站| 日本午夜一本久久久综合| 丝袜国产日韩另类美女| 三级欧美在线一区| 青青草精品视频| 久久国内精品自在自线400部| 麻豆国产精品官网| 久久国产精品99久久人人澡| 国内精品在线播放| 国产成人免费视| 成人ar影院免费观看视频| 91在线一区二区| 欧美无砖专区一中文字| 欧美精品久久99| 欧美精品三级日韩久久| 精品国精品国产尤物美女| 久久久久久久精| 国产精品美女视频| 一区二区成人在线视频| 奇米一区二区三区| 国产精品夜夜嗨| 色综合久久久网| 88在线观看91蜜桃国自产|