高級5、前綴索引

應(yīng)用場景:

數(shù)據(jù)庫里有個(gè)地址(address)字段,類型為varchar(100),業(yè)務(wù)決定了要經(jīng)常根據(jù)address來進(jìn)行查詢。

確定選擇性:

Sql代碼?

SELECT count(DISTINCT(address))/count(*) AS Selectivity FROM info;???

+-------------+????

| Selectivity |???

+-------------+????

|????? 0.8745 |???

+-------------+???

選擇性很好,但是長度為100,對整個(gè)字段建立索引顯然不合適,可以考慮建立前綴索引,例如,看看其選擇性:??

Sql代碼?

SELECT count(DISTINCT(left(address,5)))/count(*) AS Selectivity FROM info;???

+-------------+????

| Selectivity |???

+-------------+????

|?0.5981 |

+-------------+????

選擇性還不錯(cuò),但和0.8745相比還是太低,所以我們可以將前綴長度增加到10,再看看選擇性:

Sql代碼?

SELECT count(DISTINCT(left(address,10)))/count(*) AS Selectivity FROM info;???

+-------------+????

| Selectivity |???

+-------------+????

|????? 0.8239 |???

+-------------+???

和0.8745已經(jīng)很接近了,但是索引長度只有10,所以就可以決定建立前綴索引了。

前綴索引兼顧索引大小和查詢速度,但是其缺點(diǎn)是不能用于ORDER BY和GROUP BY操作,也不能用于Covering index(即當(dāng)索引本身包含查詢所需全部數(shù)據(jù)時(shí),不再訪問數(shù)據(jù)文件本身)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容