濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL Like模糊查詢速度太慢如何解決

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

熱門標(biāo)簽:百度地圖圖標(biāo)標(biāo)注中心 日照旅游地圖標(biāo)注 石家莊電商外呼系統(tǒng) 湖南人工外呼系統(tǒng)多少錢 廣東人工電話機(jī)器人 申請(qǐng)外呼電話線路 芒果電話機(jī)器人自動(dòng)化 信陽穩(wěn)定外呼系統(tǒng)運(yùn)營(yíng)商 南通自動(dòng)外呼系統(tǒng)軟件

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

Like是否使用索引?

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

  2、like keyword% 索引有效。

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

  使用mysql的explain簡(jiǎn)單測(cè)試如下:

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

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

Oracle like '%...%'優(yōu)化

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

  2、對(duì)于 like '%' (不以 % 開頭),Oracle可以應(yīng)用 colunm上的index

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

  4、非用like'%%'不可時(shí),使用Oracle內(nèi)部函數(shù):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子串第一個(gè)出現(xiàn)的位置。這與LOCATE()的雙參數(shù)形式是一樣的,不同的是參數(shù)的順序是相反的。

  INSTR(字段名, 字符串)

    這個(gè)函數(shù)返回字符串在某一個(gè)字段的內(nèi)容中的位置, 沒有找到字符串返回0,否則返回位置(從1開始)

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

  后來又嘗試將查詢一張表的sql語句,拆成好幾個(gè)sql,在服務(wù)器中同時(shí)運(yùn)行,最后在合并結(jié)果。奈何道行太淺,這個(gè)實(shí)現(xiàn)也沒那么好。

  還嘗試建立全文索引,數(shù)據(jù)庫(kù)居然不讓這么干

  最終是需求方妥協(xié),采用 Like keyword% 的格式使用索引    

  對(duì)于Like模糊查詢的解決方案,若有大神賜教,不吝感激!

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • mysql中模糊查詢的四種用法介紹
  • MySql like模糊查詢通配符使用詳細(xì)介紹
  • MySQL單表多關(guān)鍵字模糊查詢的實(shí)現(xiàn)方法
  • mysql模糊查詢like和regexp小結(jié)
  • Mybatis使用MySQL模糊查詢時(shí)輸入中文檢索不到結(jié)果怎么辦
  • 淺談MySQL模糊查詢中通配符的轉(zhuǎn)義
  • PHP MYSQL實(shí)現(xiàn)登陸和模糊查詢兩大功能
  • mysql模糊查詢like與REGEXP的使用詳細(xì)介紹
  • mysql中l(wèi)ike % %模糊查詢的實(shí)現(xiàn)
  • 深入探究Mysql模糊查詢是否區(qū)分大小寫

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL Like模糊查詢速度太慢如何解決》,本文關(guān)鍵詞  MySQL,Like,模糊,查詢,速度,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL Like模糊查詢速度太慢如何解決》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于MySQL Like模糊查詢速度太慢如何解決的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    林西县| 黄山市| 巫溪县| 德钦县| 越西县| 桃江县| 呈贡县| 淮北市| 绥棱县| 监利县| 曲水县| 丰原市| 抚顺县| 台中市| 鞍山市| 合川市| 安塞县| 政和县| 平南县| 秀山| 吉隆县| 开鲁县| 辽阳县| 金坛市| 余庆县| 秦安县| 泰州市| 莱西市| 凤凰县| 阳春市| 新干县| 化德县| 沙湾县| 普宁市| 天镇县| 南充市| 木里| 辽宁省| 平和县| 西贡区| 延边|