av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術(shù)文章
文章詳情頁

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

瀏覽:4日期:2023-10-10 14:16:24

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

Like是否使用索引?

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

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 ’%...%’優(yōu)化

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

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

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

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

INSTR(字段名, 字符串)

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

SELECT * FROM tblTopic ORDER BY INSTR( topicTitle, ’ha’ ) > 0 DESCSELECT INSTR( topicTitle, ’ha’ ) FROM tblTopic

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

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

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

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: MySQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 四虎三级 | av一区二区在线观看 | 久久av一区 | 亚洲欧美日韩国产 | 亚洲另类视频 | 亚洲69视频 | 4438成人网 | 99视频+国产日韩欧美 | 天天插天天插 | 成人国产精品一区二区 | 在线a视频 | 精品国产一区二区三区久久久蜜月 | 欧美在线小视频 | 日韩黄色一级片 | 日韩免费精品视频 | 中文字幕二区 | 国产成年妇视频 | 成人一级片 | 日本一区二区三区在线视频 | 日韩欧美综合 | 欧美激情一区二区 | 色妞色视频一区二区三区四区 | 欧美三级在线看 | 亚洲精品三区 | 日本中文在线观看 | 亚洲欧美视频在线观看 | 日韩精品久久久 | 亚洲成av| 秋霞啪啪片 | 在线观看一区 | 欧美在线一区二区三区 | 国产一级18片视频 | 国产在线成人 | 成年人小视频 | 日本成人一区二区三区 | 久久久亚洲一区 | 亚洲福利一区二区 | 亚洲欧美成人 | 永久黄网站色视频免费观看w | 在线观看国产小视频 | 日韩一级免费视频 |