1. 程式人生 > 資料庫 >MySQL Like模糊查詢速度太慢如何解決

MySQL Like模糊查詢速度太慢如何解決

問題:明明建立了索引,為何Like模糊查詢速度還是特別慢?

Like是否使用索引?

  1、like %keyword 索引失效,使用全表掃描。但可以通過翻轉函式+like前模糊查詢+建立翻轉函式索引=走翻轉函式索引,不走全表掃描。

  2、like keyword% 索引有效。

  3、like %keyword% 索引失效,也無法使用反向索引。

  使用mysql的explain簡單測試如下:

  explain select * from company_info where cname like '%小%'

MySQL Like模糊查詢速度太慢如何解決

  explain select * from company_info where cname like '小%'

MySQL Like模糊查詢速度太慢如何解決

Oracle like '%...%'優化

  1、儘量不要使用 like '%%'

  2、對於 like '%' (不以 % 開頭),Oracle可以應用 colunm上的index

  3、對於 like '%…' 的 (不以 % 結尾),可以利用reverse + function index 的形式,變化成 like '%'

  4、非用like'%%'不可時,使用Oracle內部函式:INSTR()解決。

  select * from emp2 where job like '%RE%' and ename like '%A%' and mgr like '%3%' ; --走全表掃描,速度慢

  select * from emp where instr(job,'RE')>0 and instr(ename,'A')>0 and instr(mgr,'3')>0 ; --只查詢欄位,速度快

MySQL中的INSTR(與Oracle中的不一樣)

  INSTR(str,substr)

    返回字串str串中substr子串第一個出現的位置。這與LOCATE()的雙引數形式是一樣的,不同的是引數的順序是相反的。

  INSTR(欄位名,字串)

    這個函式返回字串在某一個欄位的內容中的位置,沒有找到字串返回0,否則返回位置(從1開始)

    SELECT * FROM tblTopic ORDER BY INSTR( topicTitle,'ha' ) > 0 DESC

    SELECT INSTR( topicTitle,'ha' ) FROM tblTopic

  後來又嘗試將查詢一張表的sql語句,拆成好幾個sql,在伺服器中同時執行,最後在合併結果。奈何道行太淺,這個實現也沒那麼好。

  還嘗試建立全文索引,資料庫居然不讓這麼幹

  最終是需求方妥協,採用 Like keyword% 的格式使用索引    

  對於Like模糊查詢的解決方案,若有大神賜教,不吝感激!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。