激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

香港云服务器
服務器之家 - 數據庫 - Mysql - MySQL中Like模糊查詢速度太慢該如何進行優化

MySQL中Like模糊查詢速度太慢該如何進行優化

2022-01-24 17:44小王java Mysql

在業務場景中經常會用到like模糊查詢,但是大家都知道,like是用不到索引的,所以當數據量非常大時,速度會非常慢,這篇文章主要給大家介紹了關于MySQL中Like模糊查詢速度太慢該如何進行優化的相關資料,需要的朋友可以參考下

一、前言:

我建了一個《學生管理系統》,其中有一張學生表和四張表(小組表,班級表,標簽表,城市表)進行聯合的模糊查詢,效率非常的低,就想了一下如何提高like模糊查詢效率問題

注:看本篇博客之前請查看:mysql中如何查看sql語句的執行時間

二、第一個思路建索引

1、like %keyword 索引失效,使用全表掃描。

2、like keyword% 索引有效。

3、like %keyword% 索引失效,使用全表掃描。

使用explain測試了一下:

原始表(注:案例以學生表進行舉例)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
-- 用戶表
create table t_users(
                        id int primary key auto_increment,
-- 用戶名
                        username varchar(20),
-- 密碼
                        password varchar(20),
-- 真實姓名
                        real_name varchar(50),
-- 性別 1表示男  0表示女
                        sex int,
-- 出生年月日
                        birth date,
-- 手機號
                        mobile varchar(11),
-- 上傳后的頭像路徑
                        head_pic varchar(200)
);

建立索引

?
1
2
#create index 索引名 on 表名(列名);                
create index username on t_users(username);

like %keyword% 索引失效,使用全表掃描

?
1
2
explain select id,username,password,real_name,sex,birth,mobile,head_pic
 from t_users where username like '%h%';

MySQL中Like模糊查詢速度太慢該如何進行優化

like keyword% 索引有效。

?
1
2
explain select id,username,password,real_name,sex,birth,mobile,head_pic
from t_users where username like 'wh%';

MySQL中Like模糊查詢速度太慢該如何進行優化

like %keyword 索引失效,使用全表掃描。

MySQL中Like模糊查詢速度太慢該如何進行優化

三、instr

這個我最開始都沒聽說過,今天查閱了一下資料,才知道有這個寶貝東西,

instr(str,substr)返回字符串str串中substr子串第一個出現的位置,沒有找到字符串返回0,否則返回位置(從1開始)

?
1
2
3
4
5
6
7
8
#instr(str,substr)方法
select id,username,password,real_name,sex,birth,mobile,head_pic
      from t_users 
      where instr(username,'wh')>0 #0.00081900
#模糊查詢
select id,username,password,real_name,sex,birth,mobile,head_pic
        from t_users
        where username like 'whj'; # 0.00094650

MySQL中Like模糊查詢速度太慢該如何進行優化

MySQL中Like模糊查詢速度太慢該如何進行優化

比較兩個效率差距不大主要原因是數據較少,最好多準備點原始數據進行測試效果最佳

附:like是否使用索引?

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

  2、like keyword%    索引有效。

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

總結

到此這篇關于mysql中like模糊查詢速度太慢該如何進行優化的文章就介紹到這了,更多相關mysql like模糊查詢慢優化內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_44385486/article/details/121916824

延伸 · 閱讀

精彩推薦
719
主站蜘蛛池模板: 欧日韩| 国产亚洲精品久久久久婷婷瑜伽 | gogo全球大胆高清人露出91 | 国产亚洲小视频 | 色综合欧美 | 性日本xxx | 蜜桃一本色道久久综合亚洲精品冫 | 色中色激情影院 | 欧美日韩亚洲另类 | 亚洲欧美不卡视频 | 国产午夜精品一区二区三区四区 | 国产一精品久久99无吗一高潮 | 国产精品hd免费观看 | 国产亚洲精品久久久久5区 男人天堂免费 | 欧美中文字幕一区二区三区亚洲 | 日本特级a一片免费观看 | 美女污污视频在线观看 | 毛片韩国 | 二级大黄大片高清在线视频 | 毛片一级网站 | 黄色一级片在线免费观看 | 草草视频在线播放 | 黄色av网站免费看 | 免费在线观看成人网 | 日本一道aⅴ不卡免费播放 视屏一区 | 密室逃脱第一季免费观看完整在线 | 亚洲一区免费电影 | 在线成人看片 | 九九精品视频免费 | 久久久久久久久久久久久久久久久久 | 日韩专区在线 | 成人三级在线播放 | 亚洲成人在线免费 | 国产在线观看一区二区三区 | 99久久久精品视频 | 午夜伊人 | av电影免费在线 | 亚洲一区二区三区91 | av在线免费不卡 | 色99久久| 日本网站一区二区三区 |