什么是回表
回表是數(shù)據(jù)庫(kù)查詢優(yōu)化中常用的技術(shù)。當(dāng)我們?cè)诓樵円粡埡卸鄠€(gè)字段的表時(shí),如果需要返回的字段不是全部的字段,那么在查詢時(shí),就需要先根據(jù)條件查詢出記錄所在的行(使用索引),然后再去讀取磁盤(pán)中的對(duì)應(yīng)記錄并返回結(jié)果。這個(gè)過(guò)程中,查詢記錄所在行的步驟就是回表。
哪些情況下不用回表
在MySQL中,有些情況下不需要進(jìn)行回表操作,這可以讓查詢更快。下面列出了一些情況。
使用 covering Index 查詢:當(dāng)查詢所需要的字段都被包含在了一個(gè)索引中時(shí),MySQL 可以直接從索引樹(shù)中讀取數(shù)據(jù),而不是回表。
使用輔助索引掃描完成查詢需求:查詢時(shí)如果不需要返回全部記錄,那么如果用含有查詢條件的輔助索引進(jìn)行掃描,就可以直接將輔助索引中的字段全部讀取,避免了回表操作。
使用Cluster Index查詢:MySQL InnoDB 存儲(chǔ)引擎中,對(duì)于使用主鍵的表,主鍵值和其它數(shù)據(jù)都保存在了同一個(gè) B-Tree 中,這樣當(dāng)通過(guò)主鍵進(jìn)行查詢時(shí),就可以避免回表操作,直接從 B-Tree 結(jié)構(gòu)中讀取數(shù)據(jù)。
如何避免回表的出現(xiàn)
想要避免回表的出現(xiàn),我們可以做的有很多。
盡量使用 covering index 查詢(即索引覆蓋)。
對(duì)于查詢時(shí)需要的字段,都在輔助索引中設(shè)置,正常查詢時(shí)只需要掃描輔助索引即可。
在設(shè)計(jì)數(shù)據(jù)表時(shí),可以通過(guò) Cluster Index 技術(shù),將主鍵和其它字段保存在同一個(gè) B-Tree 中。
盡量使用聚集索引。
結(jié)尾
回表技術(shù)在數(shù)據(jù)庫(kù)查詢優(yōu)化中起到了重要的作用。但是,如果沒(méi)有必要,我們又應(yīng)該盡量避免它的出現(xiàn)。合適的索引、數(shù)據(jù)表設(shè)計(jì)和優(yōu)化,可以有效地降低回表的發(fā)生頻率,提高查詢效率。