摘要:轉載地址索引對于一個數據庫的影響相信大家一定了解,如果一個查詢命令進入到數據庫中后,查詢優化器沒有找到合適的索引,那么數據庫會進行全集合掃描在中也叫全表掃描,全集合查詢對于性能的影響是災難性的。如果數據的顆粒過大,索引就無法發揮該有的性能。
轉載地址:http://forum.foxera.com/mongo...
索引對于一個數據庫的影響相信大家一定了解,如果一個查詢命令進入到數據庫中后,查詢優化器沒有找到合適的索引,那么數據庫會進行全集合掃描(在RDBMS中也叫全表掃描),全集合查詢對于性能的影響是災難性的。沒有索引的查詢就如同在詞典那毫無規律的海量詞匯中獲得某個你想要的詞匯,但這個詞典是沒有目錄的,只能通過逐頁來查找。這樣的查找可能會讓你耗費幾個小時的時間,但如果要求你查詢詞匯的頻率如同用戶訪問的頻率一樣的話。。。嘿嘿,我相信你一定會大喊“老子不干了!”。顯然計算機不會這樣喊,它一直是一個勤勤懇懇的員工,不論多么苛刻的請求他都會完成。
在MongoDB中索引的類型與RDBMS中大體一致,我們不做過多重復,我們來看一下在MongoDB中如何才能更高效的利用索引。
1.索引越少越好
索引可以極大地提高查詢性能,那么索引是不是越多越好?答案是否定的,并且索引并非越多越好,而是越少越好。每當你建立一個索引時,系統會為你添加一個索引表,用于索引指定的列,然而當你對已建立索引的列進行插入或修改時,數據庫則需要對原來的索引表進行重新排序,重新排序的過程非常消耗性能,但應對少量的索引壓力并不是很大,但如果索引的數量較多的話對于性能的影響可想而知。所以在創建索引時需要謹慎建立索引,要把每個索引的功能都要發揮到極致,也就是說在可以滿足索引需求的情況下,索引的數量越少越好。
一. 隱式索引
//建立復合索引 db.test.ensureIndex({"age": 1,"no": 1,"name": 1 })
我們在查詢時可以迅速的將age,no字段進行排序,隱式索引指的是如果我們想要排序的字段包含在已建立的復合索引中則無需重復建立索引。
db.test.find().sort("age": 1,"no": 1) db.test.find().sort("age": 1)
如以上兩個排序查詢,均可使用上面的復合索引,而不需要重新建立索引。
二. 翻轉索引
//建立復合索引 db.test.ensureIndex({"age": 1})
翻轉索引很好理解,就是我們在排序查詢時無需考慮索引列的方向,例如這個例子中我們在查詢時可以將排序條件寫為"{"age": 0}",依舊不會影響性能。
2.索引列顆粒越小越好
什么叫顆粒越小越好?在索引列中每個數據的重復數量稱為顆粒,也叫作索引的基數。如果數據的顆粒過大,索引就無法發揮該有的性能。例如,我們擁有一個"age"列索引,如果在"age"列中,30歲占了40%,如果現在要查詢一個30歲,名叫"Tom"的人,我們則需要在表的40%的數據中查詢,索引的作用大大降低。所以,我們在建立索引時要盡量將數據顆粒小的列放在索引左側,以保證索引發揮最大的作用。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/19362.html
摘要:大家在使用的時候有沒有碰到過性能問題呢這里總結了性能優化的五個步驟,希望能夠有所幫助。第四步使用稀疏索引來減少空間占用如果使用,并重度使用關鍵字,可以使用來減少空間占用提升查詢的性能。 MongoDB 一直是最流行的 NoSQL,而根據 DB-Engines Ranking 最新的排行,時下 MongoDB 已經擊敗 PostgreSQL 躍居數據庫總排行的第四位,僅次于 Oracle...
摘要:年月日本文是關于記錄某次游戲服務端的性能優化此處涉及的技術包括引擎隨著游戲導入人數逐漸增加單個集合的文檔數已經超過經常有玩家反饋說卡特別是在服務器遷移后從核降到核卡頓更嚴重了遂開始排查問題確認服務器壓力首先使用命令查看總體情況此時占用不高 Last-Modified: 2019年6月13日11:08:19 本文是關于記錄某次游戲服務端的性能優化, 此處涉及的技術包括: MongoDB...
摘要:年月日本文是關于記錄某次游戲服務端的性能優化此處涉及的技術包括引擎隨著游戲導入人數逐漸增加單個集合的文檔數已經超過經常有玩家反饋說卡特別是在服務器遷移后從核降到核卡頓更嚴重了遂開始排查問題確認服務器壓力首先使用命令查看總體情況此時占用不高 Last-Modified: 2019年6月13日11:08:19 本文是關于記錄某次游戲服務端的性能優化, 此處涉及的技術包括: MongoDB...
摘要:活動之圖文直播現在,在現場為大家發來報道大會在主持人甜美的聲音中開場,來自,作為中文社區的官方合作伙伴,是這次大會的特別支持。 11月22日,MongoDB 2014大會在北京拉開帷幕,這是一場程序員,架構師和運維工程師齊聚的技術盛會,會上,MongoDB頂級專家對MongoDB性能調試與擴展、模式設計藝術、集群管理及遷移以及大規模的使用等方面做了詳細講解,有200多開發者參與了此次盛...
摘要:優志愿張海鵬宋體背景宋體每年月下旬到月下旬期間是高考填志愿的高峰期,也是優志愿后端面臨大流量高并發請求的業務高峰期。對于優志愿讀多寫少的場景及其業務高峰期,用戶可以按需增刪節點,更好地實現讀取性能的擴展。 隨著用戶規模的增長,數據庫的壓力也在成倍增加。面對大流量、高并發,UCloud MongoDB 做到了高效,并展現出了更好的性能體驗。 —— 優志愿 CTO 張海鵬 背景...
閱讀 1972·2021-11-25 09:43
閱讀 653·2021-10-11 10:58
閱讀 1730·2019-08-30 15:55
閱讀 1725·2019-08-30 13:13
閱讀 736·2019-08-29 17:01
閱讀 1840·2019-08-29 15:30
閱讀 789·2019-08-29 13:49
閱讀 2172·2019-08-29 12:13