前言
在有一些情況下,開發(fā)同學經(jīng)常使用like去實現(xiàn)一些業(yè)務需求,當使用like時,我們都知道使用like 前%(like ‘%111')這種情況是無法使用索引的,那么如何優(yōu)化此類的SQL呢,下面是一個案例。
原SQL如下:
pcc_cust_infonew 表索引如下
執(zhí)行設計如下:
這里可以看到SQL執(zhí)行3.96秒,執(zhí)行計劃中也可以發(fā)現(xiàn)PCC_CUST_INFONEW表走TABLE ACCESS FULL掃描,返回約380k的數(shù)據(jù),然后再與PCC_CUST_CONTRACTCOMPANY表主鍵PK_PCC_CUST_CONTRACTCOMPANY走INDEX UNIQUE SCAN,這里慢主要是執(zhí)行計劃中為3的這一步。
我們也都知道在Oracle中,當使用like時,如果是后%(like ‘138%')是可以使用索引的,如果是前%(like ‘%138')是無法正常使用索引。那么如何讓前%也可以使用到索引呢,答案是可以使用reverse索引的形式進行優(yōu)化。
優(yōu)化如下:
修改索引
將SQL調整為
按以上調整后,SQL執(zhí)行效率提升到毫秒級。
調整后的執(zhí)行計劃如下:
那使用reverse函數(shù)索引后,到底是如何做到可以使用索引了呢,當你看到執(zhí)行計劃下面的謂詞信息想必你就知道答案了,
其實就是使用reverse函數(shù)索引將索引數(shù)據(jù)反轉,SQL中的where條件中將值反轉,這樣就將前%改為后%。
總結
以上就是關于使用reverse索引優(yōu)化like語句的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。