日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當前位置:軟件下載吧 > 數據庫 > DB2 > MongoDB數據庫查詢性能提高40倍的經歷分享

MongoDB數據庫查詢性能提高40倍的經歷分享

時間:2024-02-14 10:20作者:下載吧人氣:21

前言

數據庫性能對軟件整體性能有著至關重要的影響,本文給大家分享了一次MongoDB數據庫查詢性能提高40倍的經歷,感興趣的朋友們可以參考學習。

背景說明

1、數據庫:MongoDB

2、數據集:

  • A:字段數不定,這里主要用到的兩個UID和Date
  • B:三個字段,UID、Date、Actions。其中Actions字段是包含260元素JSON數組,每個JSON對象有6個字段。共有數據800萬條左右。

3、業務場景:求平均數

  • 通過組合條件從A數據表查詢出(UID,Date)列表,最多可能包含數萬條記錄;
  • 然后用第1步的結果從B中查詢出對應的數據
  • 用第2步結果去Actions的某個固定位置的元素的進行計算

進化過程

在這里使用Python演示

最直接想到的方法

根據上面的業務場景描述,最容易想到的解決方法就是

from pymongo import MongoClient
# 連接數據庫
db = MongoClient('mongodb://127.0.0.1:27017')['my_db']

# 簡化的查詢數據集A的條件
filter = {...}
# 查詢Collection A
a_cursor = db.a.find(_filter)
a_docs = [x for x in a_cursor]

# 變量的初始定義
count = 0
total = 0
# 加入需要用到的元素為第21個
index = 20
# 查詢Collection B,同時做累加
for a_doc in a _docs:
 b_doc = db.b.find_one({'uid':a_doc['uid'], 'date': a_doc['date']})
 # 只有能查到相應的結果時,才可以
 if b_doc is not None:
 total += b_doc['actions'][20]['number']
 count += 1

 # 求平均數
 if count > 0 :
 avg = total/count
標簽MongoDB,數據庫,查詢,性能,提高,40倍,經歷,分享

相關下載

查看所有評論+

網友評論

網友
您的評論需要經過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 亚洲国产精品区 | 欧美成人在线免费 | 日韩在线视频免费不卡一区 | 又黄又刺激下面流水的视频 | 欧美亚洲免费久久久 | 午夜久久久久久久 | 美女扒开腿让男人桶爽免费动态图 | 国产亚洲一区二区三区 | 美国第一毛片 | 国产精品国产三级国产在线观看 | 偷拍小视频99在线 | 日本高清aⅴ毛片免费 | 特大一级aaaaa毛片 | 国产成人精品在视频 | 日日摸人人拍人人澡 | 美女日韩在线观看视频 | 自拍视频在线 | 女人张开腿让男人桶视频 | 欧美精品国产制服第一页 | 久久精品国产一区二区 | 日本久久久久一级毛片 | 国产成人一区二区三区高清 | 特级毛片免费视频播放 | 亚洲欧美在线一区二区 | 久草国产在线观看 | 欧美一级毛片俄罗斯 | 日本欧美国产精品 | 久青草免费视频手机在线观看 | 一区二区影视 | 在线观看国产日韩 | 国产综合第一页 | 亚洲欧美视频一区二区三区 | 色拍拍噜噜噜aⅴ在线观看 色青青草原桃花久久综合 色婷婷91 | 国产99高清一区二区 | 亚洲高清一区二区三区久久 | 真正国产乱子伦高清对白 | 免费在线观看a | 国产成人精品亚洲 | 欧美一级毛片激情 | 国产成人免费片在线观看 | 91香蕉成人免费网站 |