91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MySQL Like模糊查詢速度慢的解決方法

發布時間:2020-10-27 20:25:58 來源:億速云 閱讀:871 作者:Leah 欄目:開發技術

本篇文章給大家分享的是有關MySQL 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模糊查詢的解決方案,若有大神賜教,不吝感激!

以上就是MySQL Like模糊查詢速度慢的解決方法,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

任丘市| 定西市| 曲水县| 成武县| 佛坪县| 邻水| 上思县| 普兰县| 仁布县| 巧家县| 万宁市| 莱西市| 柘荣县| 清徐县| 建水县| 临江市| 丁青县| 庆云县| 晋宁县| 罗田县| 筠连县| 读书| 临清市| 武隆县| 安平县| 嵊州市| 蒙阴县| 秭归县| 仁布县| 孝感市| 光泽县| 耒阳市| 金湖县| 福鼎市| 徐水县| 台湾省| 尼木县| 西平县| 广灵县| 汕头市| 阿荣旗|