《DBNotes:single_table訪問方法、MRR多范圍讀取優化、索引合并》

目錄

  • single_table訪問方法
    • const
    • ref
    • ref_or_null
    • range
    • index
    • all
  • MRR多范圍讀取優化
  • 索引合并
    • intersection
    • union
    • sort-union

single_table訪問方法

const

在主鍵列或者unique二級索引與一個常數進行等值比較時才有效。
如果主鍵或者unique二級索引的索引列由多個列構成,則只有在索引列中的每個列都與常數進行等值比較時,才是const訪問

ref

搜索條件為二級索引(非unique)與常數進行等值比較,形成的掃描區間為單點掃描區間(即【‘abc’,‘abc’】),采用二級索引來執行查詢的訪問方法為ref。注意采用二級索引執行查詢時,每獲取到一條二級索引記錄就會進行一次回表操作。
TIPS:

  • 二級索引列允許存儲NULL值時不限制NULL值的數量,所以執行key is NULL查詢時最優只能執行ref操作
  • 索引列中包含多個列的二級索引時,只要最左邊連續的列是與常數進行等值比較,就可以使用ref訪問。

ref_or_null

當想找出某個二級索引列的值等于某個常數的記錄,并且將該列中值為NULL的記錄也找出來:

select * from single_table where key1 = 'abc' or key1 is null;

若使用二級索引,此時的掃描區間為:[‘abc’,‘abc’] 以及[NULL,NULL]。
這種訪問方法即為ref_or_null。

range

select * from single_table where key2 IN (1438,6328) OR (key2 >= 38 AND key2 <= 79);

使用二級索引,掃描區間為[1438,1438] 、[6328,6328]、[38,79],改掃描區間為若干個單點掃描區間或者范圍掃描區間。訪問方法為range。當然(-無窮,+無窮)不為range訪問方法。

index

key_part1,key_part2,key_part3 為二級索引,它們三個構成了一個聯合索引,并且key_table2并不是聯合索引的最左列。

select key_part1,key_part2,key_part3 from single_table where key_table2 = 'abc'; 

此時無法形成合適的范圍區間來減少掃描的記錄數量。
需要注意此時的查詢符合兩個條件:

  • 查詢列表中key_part1,key_part2,key_part3,都包含在聯合索引中
  • 搜索條件只有key_part2,這個列也包含在聯合索引中
    很顯然,需要掃描全部的聯合索引,掃描區間為[-無窮,+無窮]。由于二級索引記錄只有存放索引列和主鍵,也不需要回表,所以此時掃描去不的二級索引記錄比直接掃描全部的聚集索引記錄成本要小。這種方法稱為index訪問。

又如:

select * from single_table order by id;

通過全表掃描對表進行查詢時有order by。此時也是使用index方法。

all

全表掃描,直接掃描全部的聚集索引記錄。

MRR多范圍讀取優化

select * from single_table where key1 = 'abc' and key2 > 1000; 

該語句的執行步驟:
1、通過key1的索引定位掃描區間[‘abc’,‘abc’];
2、根據上面得到的主鍵值回表,得到完整用戶記錄,然后檢測記錄是否滿足key2 > 1000的條件,滿足則返回
3、重復2步驟,直到不滿足key1 = ‘abc’
每次從二級索引中讀取到一條記錄后,就會根據該記錄的主鍵值執行回表操作。
而某個掃描區間中的二級索引記錄的主鍵值是無序的,每次回表都會隨機讀取一個聚集索引頁面,帶來的IO開銷較大。
MRR會先讀取一部分二級索引記錄,將它們的主鍵值排序后再同意執行回表操作,節省IO開銷。

索引合并

intersection

使用多個索引完成一次查詢的執行方法稱為索引合并

select * from single_table where key1 = 'a' and key3 = 'b';

可以先搜key1的索引,然后回表,根據key3條件篩選。
也可以先搜key1的索引,然后回表,根據key1條件篩選。
當然可以同時使用key1和key2的索引。在key1索引中掃描key1值得到區間[‘a’,‘a’],在key3索引中掃描key3值得到區間[‘b’,‘b’];
然后從兩者操作結果中找到id列值相同的記錄。然后根據共有的id值執行回表,這樣可能會省下回表操作帶來的開銷。
當然需要注意的是要求從不同二級索引中獲取到的二級索引記錄都按照主鍵值排好序:

  • 從兩個有序集合中取交集比兩個從無序集合中取交集要容易
  • 如果獲取到的id值有序排列,則在根據這些id值執行回表操作時不再是進行單純的隨機IO,就會提高效率。

如果從掃描區間中獲得的記錄并不是按照主鍵值排序的,那么就不能使用intersection索引合并。

union

select * from single_table where key1 = 'a' or key3 = 'b';

同時使用key1和key2的索引。在key1索引中掃描key1值得到區間[‘a’,‘a’],在key3索引中掃描key3值得到區間[‘b’,‘b’];
然后對兩個結果進行去重,對去重后的id值進行回表操作。
同樣二級索引記錄都是要按照主鍵值排序,如果從掃描區間中獲得的記錄并不是按照主鍵值排序的,那么就不能使用union索引合并。

sort-union

union索引合并條件苛刻,下面的查詢就不能使用union索引合并

select * from single_table where key1 < 'a' or key3 > 'z';

我們可以這樣操作;
1、根據key1<'a’條件從key1的二級索引中獲取記錄,并將獲取到的記錄的主鍵值排序
2、根據key3<'z’條件從key3的二級索引中獲取記錄,并將獲取到的記錄的主鍵值排序
3、按照union操作兩個記錄合并
sort-union 索引合并比union索引合并多了一步對二級索引記錄的主鍵值進行排序。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/377076.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/377076.shtml
英文地址,請注明出處:http://en.pswp.cn/news/377076.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

怎樣通過命令管理Windows7桌面防火墻

&#xff08;1&#xff09;啟用桌面防火墻netsh advfirewall set allprofiles state on&#xff08;2&#xff09;設置默認輸入和輸出策略netsh advfirewall set allprofiles firewallpolicy allowinbound,allowoutbound以上是設置為允許&#xff0c;如果設置為拒絕使用blockin…

ruby推送示例_Ruby for循環示例

ruby推送示例for循環 (The for loop) In programming, for loop is a kind of iteration statement which allows the block to be iterated repeatedly as long as the specified condition is not met or a specific number of times that the programmer knows beforehand. …

《DBNotes: Buffer Pool對于緩沖頁的鏈表式管理》

目錄Buffer Pool回顧Buffer Pool內部組成freelistflushlistLRU鏈表管理以及改進Buffer Pool回顧 我們知道針對數據庫的增刪改刪操作都是在Buffer Pool中完成的&#xff0c;一條sql的執行步驟可以認為是這樣的&#xff1a; 1、innodb存儲引擎首先在緩沖池中查詢有沒有對應的數據…

一個延時調用問題

如果用下面第1行的寫法&#xff0c;調用 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:selector(removeFromSuperview) object:nil]; 可以生效 如果用下面第3行的寫法&#xff0c;調用 [NSObject cancelPreviousPerformRequestsWithTarget:self selector:…

onclicklistener 方法使用匯總

相信很多像我一樣的新手學習ANDROID開發會遇到這個問題&#xff0c;通過這幾天的歸類和總結&#xff0c;將我的理解寫在下面&#xff0c;歡迎大家一起前來討論&#xff1a; 以按鈕BUTTON的監聽事件為例&#xff0c;以下的監聽實現都是等價的&#xff1a; 1.使用接口繼承按鈕監聽…

《源碼分析轉載收藏向—數據庫內核月報》

月報原地址&#xff1a; 數據庫內核月報 現在記錄一下&#xff0c;我可能需要參考的幾篇文章吧&#xff0c;不然以后還得找&#xff1a; MySQL 代碼閱讀 MYSQL開源軟件源碼閱讀小技巧 MySQL 源碼分析 聚合函數&#xff08;Aggregate Function&#xff09;的實現過程 MySQL …

vim中的jk為什么是上下_JK的完整形式是什么?

vim中的jk為什么是上下JK&#xff1a;開玩笑 (JK: Just Kidding) JK is an abbreviation of "Just Kidding". JK是“ Just Kidding”的縮寫 。 It is an expression, which is commonly used in messaging or chatting on social media networking sites like Faceb…

百度歸來的學長做報告

今天下午下課到現在才總算閑下來&#xff0c;本來計劃這個時間應該是讀英語&#xff0c;做英語模擬題的時間&#xff0c;但是&#xff0c;我不得不寫點什么來記錄下剛才的事——在百度實習并且簽下工作的學長做報告。 原本認為每個人的成功&#xff08;請允許我目前的眼光簽個好…

轉:Google論文之三----MapReduce

文章來自于&#xff1a;http://www.cnblogs.com/geekma/p/3139823.html MapReduce&#xff1a;大型集群上的簡單數據處理 摘要 MapReduce是一個設計模型&#xff0c;也是一個處理和產生海量數據的一個相關實現。用戶指定一個用于處理一個鍵值&#xff08;key-value&#xff09;…

合約 cd 模式_CD的完整形式是什么?

合約 cd 模式CD&#xff1a;光盤 (CD: Compact Disc) CD is an abbreviation of "Compact Disc". CD是“ Compact Disc”的縮寫 。 It is a digital optical disc originally developed to store the audio of recordings in the format of a data file used as a p…

《DBNotes:Join算法的前世今生》

目錄NestLoopJoin算法Simple Nested-Loop JoinIndex Nested-Loop JoinBlock Nested-Loop JoinBatched Key AccessHash Join算法In-Memory Join(CHJ)On-Disk Hash Join參考鏈接在8.0.18之前&#xff0c;MySQL只支持NestLoopJoin算法&#xff0c;最簡單的就是Simple NestLoop Joi…

如何解決迅雷插件導致IE10崩潰的問題

Windows 8里面帶的IE10酷不酷&#xff1f;沉浸式界面果然不同凡響&#xff0c;IE10讓人幾乎認不出來了&#xff01;這是微軟的瀏覽器么&#xff1f;上面這張圖是Windows8下Metro UI的新界面IE10&#xff0c;不過當我們切換回傳統桌面的時候&#xff0c;也有IE10的經典版的。好吧…

UNITY3D與iOS交互解決方案

原地址&#xff1a;http://bbs.18183.com/thread-456979-1-1.html 本帖最后由 啊,將進酒 于 2014-2-27 11:17 編輯 “授人以魚&#xff0c;不如授人以漁”&#xff0c;以UNITY3D調用iOS版的91SDK為例&#xff0c;利用C# / C / OBJ-C交互原理,本文將詳細介紹UNITY3D與iOS之間交互…

c:if equal_C ++中的std :: equal()

c:if equalequal()作為STL函數 (equal() as a STL function) Syntax: 句法&#xff1a; bool equal(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2);Where, 哪里&#xff0c; InputIterator1 first iterator to start of the first sequence range I…

《DBNotes:Buffer Pool刷臟頁細節以及改進》

本筆記知識沿用之前DBNotes: Buffer Pool對于緩沖頁的鏈表式管理的部分知識 目錄獲取一個空閑頁的源碼邏輯Page_Cleaner_ThreadLRU_Manager_ThreadHazard Pointer作為驅逐算法改進參考獲取一個空閑頁的源碼邏輯 任何一個讀寫請求都需要從Buffer pool來獲取所需頁面。如果需要的…

WordPress刪除數據中標題重復文章的方法

一種是刪除重復的方法是&#xff1a;使用插件,大家可以去官網上下載 二種刪除重復的方法是&#xff1a;登錄數據庫&#xff0c;使用sql語句刪除&#xff0c;具體的語句為如下代碼&#xff1a; CREATE TABLE my_tmp AS SELECT MIN(ID) AS col1 FROM wp_posts GROUP BY post_titl…

hibernate配置

hibernate.cfg.xml <?xml version"1.0" encoding"UTF-8"?> <!DOCTYPE hibernate-configuration PUBLIC"-//Hibernate/Hibernate Configuration DTD 3.0//EN""http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd&quo…

html中表單元素_HTML中的表單元素

html中表單元素1)<input>元素 (1) The <input> Element) The <input> element is used to get input from the user in an HTML form. <input>元素用于以HTML形式從用戶獲取輸入。 <input> tag is used to get input using input element, the …

《搜索算法——DFS、BFS、回溯》

目錄深搜200. 島嶼數量695. 島嶼的最大面積130. 被圍繞的區域547. 省份數量417. 太平洋大西洋水流問題回溯廣搜111. 二叉樹的最小深度752. 打開轉盤鎖深搜與廣搜結合934. 最短的橋深搜 深搜DFS&#xff0c;在搜索到一個新節點時&#xff0c;立即對該新節點進行遍歷&#xff0c…

AP in R

AP聚類算法是目前十分火的一種聚類算法&#xff0c;它解決了傳統的聚類算法的很多問題。不僅簡單&#xff0c;而且聚類效果還不錯。這里&#xff0c;把前兩天學習的AP算法在R語言上面的模擬&#xff0c;將個人筆記拿出來與大家分享一下&#xff0c;不談AP算法的原理&#xff0c…