青草久久影院-青草久久伊人-青草久久久-青草久久精品亚洲综合专区-SM双性精跪趴灌憋尿调教H-SM脚奴调教丨踩踏贱奴

17站長網

17站長網 首頁 數據庫 MongoDB 查看內容

mongodb查詢耗時的方法是什么?

2023-3-21 16:02| 查看: 2050 |來源: 互聯網

準備在此之前,我們先在我們的數據庫中插入10萬條數據。數據的格式是這樣的:{name:your name,age:22,gender:male,grade:2} explain explain方法是用來查看d ...

準備

在此之前,我們先在我們的數據庫中插入10萬條數據。數據的格式是這樣的:

{

 "name":"your name",

 "age":22,

 "gender":"male",

 "grade":2

}

       explain

       explain方法是用來查看db.collecion.find()的一些查詢信息的。例如:

db.collectionName.find().explain()

       explain方法有個可選的參數verbose,是個字符串,他表示的是verbose的模式。一共分為3種模式:

       queryPlanner:默認參數,詳細說明查詢優化器選擇的計劃并列出被拒絕的計劃。例如:

db.students.find({grade:1}).explain()

       executionStats:MongoDB運行查詢優化器選擇獲勝的計劃,執行計劃,完成并返回成功,統計描述的勝利計劃的執行。例如:

db.students.find({grade:1}).explain("executionStats")

       allPlansExecution:MongoDB返回描述獲獎計劃的執行以及對其他候選人統計計劃選擇方案時捕獲的統計。

       我們的目的是要記錄執行find方法的耗時時間,所以用executionStats模式就可以了。

       返回的結果也是只關注executionStats就可以了,如下圖:

nReturned:表示該查詢條件下返回的文檔數量。

executionTimeMills:表示執行時間,單位毫秒

totalDocsExamined:表示該集合總共文檔數。

       其他的屬性在這里就不多說了,記錄耗時我們只取executionTimeMills.

       Profiling

       上面提到的方法好像是只適用find方法,對于一些聚合查詢之類的查詢方法就無法統計耗時時間了。這里再介紹一個profiling方法記錄查詢耗時時間。

       開啟 Profiling 功能

       有兩種方式可以控制 Profiling 的開關和級別,第一種是直接在啟動參數里直接進行設置。

啟動MongoDB時加上-Cprofile=級別 即可。

也可以在客戶端調用db.setProfilingLevel(級別)命令來實時配置。可以通過db.getProfilingLevel()命令來獲取當前的Profile級別。

       例如:

db.setProfilingLevel(2)

db.getProfilingLevel()

       Profiling一共分為3個級別:

0 - 不開啟。

1 - 記錄慢命令 (默認為>100ms)

3 - 記錄所有命令

       Profile 記錄在級別1時會記錄慢命令,那么這個慢的定義是什么?上面我們說到其默認為100ms,當然有默認就有設置,其設置方法和級別一樣有兩種,一種是通過添 加-Cslowms啟動參數配置。第二種是調用db.setProfilingLevel時加上第二個參數:

db.setProfilingLevel( level , slowms)

db.setProfilingLevel( 1 , 10 );

       查詢 Profiling 記錄

       開啟profiling功能后,系統會把相關命令詳細信息記錄到當前數據庫的system.profile集合里。查詢方法也是跟普通的集合查詢一樣。

db.system.profile.find()

       其中,mills就是命令耗時記錄。

       由于我們設置的級別是2,所以所有命令都有記錄,現在我們把他改為級別1,且只記錄耗時20毫秒以上的記錄:

 db.setProfilingLevel( 1 , 20)

       然后我們再執行一下聚合查詢,查看下耗時時間:

db.students.aggregate( {$group:{_id:"$grade",avgAge:{$avg:"$age"}}} )

db.system.profile.find().pretty()

       可以看出,我們的這聚合查詢耗時70毫秒。

       profile 部分字段解釋

op:操作類型

ns:被查的集合

commond:命令的內容

docsExamined:掃描文檔數

nreturned:返回記錄數

millis:耗時時間,單位毫秒

ts:命令執行時間

responseLength:返回內容長度

       下面介紹幾個常用的查詢命令:

       列出執行時間長于某一限度(例如:20ms)的 Profile 記錄.

db.system.profile.find({millis:{$gt:50}})

       查看最新的 3條Profile 記錄:

db.system.profile.find().sort({$natural:-1}).limit(3)

       查看關于某個collection的相關慢查詢操作:

db.system.profile.find({ns:'mydb.students'})

       MongoDB 查詢優化

  docsExamined(掃描的記錄數)遠大于nreturned(返回結果的記錄數)的話,那么我們就要考慮通過加索引來優化記錄定位了。

  responseLength 如果過大,那么說明我們返回的結果集太大了,這時請查看find函數的第二個參數是否只寫上了你需要的屬性名。(類似 于MySQL中不要總是select)

  對于創建索引的建議是:如果很少讀,那么盡量不要添加索引,因為索引越多,寫操作會越慢。如果讀量很大,那么創建索引還是比較劃算的。

       Profiler 的效率

  Profiling 功能肯定是會影響效率的,但是不太嚴重,原因是他使用的是system.profile 來記錄,而system.profile 是一個capped collection 這種collection 在操作上有一些限制和特點,但是效率更高。

本文最后更新于 2023-3-21 16:02,某些文章具有時效性,若有錯誤或已失效,請在網站留言或聯系站長:17tui@17tui.com
·END·
站長網微信號:w17tui,關注站長、創業、關注互聯網人 - 互聯網創業者營銷服務中心

免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!

17站長網微信二維碼

始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!

掃一掃,關注站長網微信

大家都在看

熱門排行

最近更新

返回頂部
主站蜘蛛池模板: 恋夜影视列表免费安卓手机版 | 日本亚洲电影 | 午夜影院一区二区三区 | 亚洲视频无码高清在线 | 欧美18videosex | 十分钟免费看完整视频 | 日韩亚洲欧美中文高清 | 精品午夜寂寞影院在线观看 | 亚洲中文久久精品AV无码 | 国产欧美日韩精品a在线观看高清 | 日本一区二区三区在线观看网站 | 九九精彩视频在线观看视频 | 男人把女人桶到爽免费看视频 | 伊人久久中文大香线蕉综合 | 久章草一区二区 | 日本高清免费一本在线观看 | 亚洲国产综合另类视频 | 久久久性色精品国产免费观看 | 久久re热线视频国产 | 国产传媒18精品A片在线观看 | 嗯啊…跟校草在教室里做h 嗯 用力啊 嗯 c我 啊哈老师 | 精品无人区麻豆乱码1区2 | 六六影院午夜伦理 | 国产亚洲视频在线观看 | 口工漫画r18全彩啪啪 | 卫生间被教官做好爽HH视频 | 欧美三级不卡在线观线看 | 午夜向日葵视频在线观看 | 国产成人精品免费视频大全可播放的 | 99在线观看免费 | 俄罗斯XX性幻女18 | 《乳色吐息》无删减版在线观看 | 免费看欧美一级特黄a大片 免费看欧美xxx片 | 99久久综合国产精品免费 | 免费毛片a在线观看67194 | 24小时日本免费看 | 激情丛林电影完整在线 | 小荡娃奶真大 | 91麻豆精品一二三区在线 | 久久精品亚洲 | 久久中文字幕免费高清 |