国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

更多QQ空间微信QQ好友腾讯朋友复制链接
您的位置:首頁/技術文章
文章詳情頁

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

【字号: 作者:豬豬瀏覽:25日期:2023-10-10 14:16:24

問題:明明建立了索引,為何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 DESCSELECT INSTR( topicTitle, ’ha’ ) FROM tblTopic

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

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

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

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

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

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 欧美三级做爰视频 | 偷拍亚洲欧美 | 久草视频官网 | 国产成人一区在线播放 | 国内精品久久影院 | 欧美国产精品久久 | 亚洲一区二区中文字幕 | 国产精品久久久天天影视香蕉 | 国产精品国产三级国产在线观看 | 精品国产免费第一区二区 | a级毛片免费观看视频 | 国产亚洲人成网站观看 | 国产成人夜间影院在线观看 | 久久成| 最新国产三级久久 | a级毛片免费全部播放 | 国产精品久久久久国产精品 | 人人公开免费超级碰碰碰视频 | 国产在视频线在精品 | 末成年娇小性色xxxxx | 久久久久久色 | 一本三道a无线码一区v小说 | 成年人在线免费观看网站 | 美女张开腿让男生桶出水 | 免费毛片a线观看 | 色樱桃影院亚洲精品影院 | 91久久福利国产成人精品 | 99久久免费看国产精品 | 亚洲第一网站在线观看 | 国产成人综合久久精品亚洲 | 国产成人午夜性视频影院 | 欧美日韩精品在线播放 | 欧美精品videosbestsex另类 | a级毛片在线观看 | 国产美女在线精品观看 | 欧美日韩精品一区二区三区 | 一 级 黄 色 大片 | 香蕉视频在线观看黄 | 男人天堂avav | 国产免费人成在线看视频 | 免费人成黄页在线观看视频国产 |