MySQL中使用Like模糊查詢太慢


 

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

 

Like是否使用索引?

  1、like %keyword    索引失效,使用全表掃描。但可以通過翻轉函數+like前模糊查詢+建立翻轉函數索引=走翻轉函數索引,不走全表掃描。
  2、like keyword%    索引有效。
  3、like %keyword% 索引失效,也無法使用反向索引。

  使用mysql的explain簡單測試如下:
  explain select * from company_info where cname like '%小%'

  explain select * from company_info where cname 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模糊查詢的解決方案,若有大神賜教,不吝感激!

 

參考鏈接:

[1]http://www.2cto.com/database/201304/204886.html
[2]http://blog.csdn.net/zyyr365/article/details/5603555

  

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM