婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 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 '%小%'

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

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

您可能感興趣的文章:
  • mysql中模糊查詢的四種用法介紹
  • MySql like模糊查詢通配符使用詳細介紹
  • MySQL單表多關鍵字模糊查詢的實現方法
  • mysql模糊查詢like和regexp小結
  • Mybatis使用MySQL模糊查詢時輸入中文檢索不到結果怎么辦
  • 淺談MySQL模糊查詢中通配符的轉義
  • PHP MYSQL實現登陸和模糊查詢兩大功能
  • mysql模糊查詢like與REGEXP的使用詳細介紹
  • mysql中like % %模糊查詢的實現
  • 深入探究Mysql模糊查詢是否區分大小寫

標簽:呼和浩特 阿里 牡丹江 天津 惠州 公主嶺 沈陽 合肥

巨人網絡通訊聲明:本文標題《MySQL Like模糊查詢速度太慢如何解決》,本文關鍵詞  MySQL,Like,模糊,查詢,速度,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL Like模糊查詢速度太慢如何解決》相關的同類信息!
  • 本頁收集關于MySQL Like模糊查詢速度太慢如何解決的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 安泽县| 霍林郭勒市| 封丘县| 甘洛县| 昌黎县| 瑞安市| 广南县| 昌平区| 德庆县| 海南省| 拉萨市| 雷山县| 石棉县| 新乐市| 商都县| 平陆县| 九江市| 乌兰察布市| 云霄县| 东莞市| 丰顺县| 米林县| 永定县| 阿拉尔市| 鄂托克前旗| 宕昌县| 乐业县| 定日县| 民权县| 桃源县| 朝阳市| 宁陕县| 恩施市| 永康市| 嘉善县| 吉木乃县| 宁远县| 本溪市| 敦化市| 全州县| 玛曲县|