數(shù)據(jù)庫(kù)引擎是高度優(yōu)化的閉環(huán)系統(tǒng),基于執(zhí)行計(jì)劃的反饋,查詢優(yōu)化器在一定程度上自動(dòng)優(yōu)化現(xiàn)有的執(zhí)行計(jì)劃。查詢優(yōu)化的核心是索引優(yōu)化,數(shù)據(jù)庫(kù)引擎通過(guò)計(jì)數(shù)器統(tǒng)計(jì)關(guān)于索引操作的數(shù)據(jù),統(tǒng)計(jì)的信息包括:使用次數(shù)、物理存儲(chǔ)、底層操作的計(jì)數(shù),以及缺失索引等,這些統(tǒng)計(jì)數(shù)據(jù)存儲(chǔ)在內(nèi)存中,是數(shù)據(jù)庫(kù)引擎執(zhí)行情況的真實(shí)反饋,高度概括了索引的執(zhí)行情況,有意識(shí)地利用索引的統(tǒng)計(jì)信息,有針對(duì)性地優(yōu)化現(xiàn)有的業(yè)務(wù)邏輯代碼,調(diào)整查詢的執(zhí)行計(jì)劃,能夠提高數(shù)據(jù)庫(kù)的查詢性能。
一,統(tǒng)計(jì)索引的使用次數(shù)
在用戶成功提交查詢語(yǔ)句時(shí),執(zhí)行計(jì)劃中每一個(gè)單獨(dú)的索引操作(Seek,Scan,Lookup或Update)都會(huì)被統(tǒng)計(jì)到sys.dm_db_index_usage_stats 中,例如,user_updates 計(jì)數(shù)器統(tǒng)計(jì)索引執(zhí)行Insert,Update或Delete操作的次數(shù),查找計(jì)數(shù)器(user_seeks, user_scans, user_lookups)統(tǒng)計(jì)在索引上執(zhí)行的seek,scan和lookup操作的次數(shù),如果查找計(jì)數(shù)器遠(yuǎn)遠(yuǎn)小于user_updates 計(jì)數(shù)器,這說(shuō)明基礎(chǔ)表會(huì)執(zhí)行大量的更新操作,維護(hù)索引更新的開(kāi)銷比較大,數(shù)據(jù)庫(kù)引擎利用索引提升查詢性能的空間有限。
在計(jì)數(shù)時(shí),每一個(gè)單獨(dú)的seek、scan、lookup或update操作都被計(jì)算為對(duì)該索引的一次使用,并使該視圖中的相應(yīng)計(jì)數(shù)器加1。
索引的Seek,Scan,Lookup和Update的含義是:
Seek是Index Seek:通過(guò)該索引進(jìn)行查找的次數(shù)
Scan是Index Scan:通過(guò)該索引執(zhí)行掃描查找的次數(shù)
Lookup是Key Lookup:通過(guò)該索引查找到數(shù)據(jù)后,再到源數(shù)據(jù)表進(jìn)行鍵值查找的次數(shù),Key Lookup是非聚集索引特有的,查詢性能低下,應(yīng)避免這種查找方法;
Update
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動(dòng)安全 [無(wú)線安全]玩轉(zhuǎn)無(wú)線電——不安全的藍(lán)牙鎖 2017-07-26
- 消息隊(duì)列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標(biāo)分割】 2017-07-26
- 詞向量-LRWE模型-更好地識(shí)別反義詞同義詞 2017-07-26
- 從棧不平衡問(wèn)題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實(shí)現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動(dòng)安全 Android端惡意鎖屏勒索應(yīng)用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來(lái)看看(二) 2017-07-26