当前位置:首页 > 技术文章 > 5种优化方法:MySQL的Like查询

5种优化方法:MySQL的Like查询

go1234周前 (10-22)技术文章217

在MySQL中, 关于LIKE 模糊查询可能会导致性能问题,特别是当使用通配符%开头时,因为这通常会导致全表扫描。以下用5种方法可以帮助优化 LIKE 模糊查询:合理使用索引、使用反向索引、限制扫描范围、使用缓存、使用专业工具

在MySQL中, 关于LIKE 模糊查询可能会导致性能问题,特别是当使用通配符%开头时,因为这通常会导致全表扫描。

以下用5种方法可以帮助优化 LIKE 模糊查询。

图片
五种方法

第一种:合理使用索引

前缀匹配:使用LIKE '前缀%' 的形式。这种情况MySQL能够利用索引,比如:

SELECT * FROM users WHERE username LIKE '张%'

如果 username 字段有索引,前缀匹配会用到索引。

第二种:使用反向索引

对于需要匹配后缀的情况(即 LIKE '%后缀' ),可以创建一个辅助列存储反转字符串,并基于此列进行前缀匹配。

ALTER TABLE users ADD reversed username VARCHAR(255);
UPDATE users SET reversed_username = REVERSE(username);
CREATE INDEX idx_reversed username ON users(reversed_username);

其实就是创建反向字符串,到底就是一种取巧,用空间换时间。

不是不能用,看情况来。

第三种:限制扫描范围

在LIKE查询中,如果可以通过其他条件进一步缩小搜索范围,请尽量加入这些条件。

SELECT * FROM users WHERE create_time >'2023-01-01' AND username LIKE '张%';

第四种:使用缓存

如果相同的查询需要频繁执行,可以考虑在应用层实施缓存策略来减少数据库负载。

常见的比如Redis,但是这里需要注意,缓存存放的数据是很少改动的。

第五种:使用专业工具

对于非常大的数据集或者需要复杂文本处理和搜索功能,可以使用外部全文搜索引擎如Elasticsearch、Solr或者Sphinx来代替MySQL的LIKE操作。

但是我们尽量存一些关键信息,不需要把所有数据都存进去,记住他只是一个工具,能帮我们解决问题即可。

通过这些方法优化LIKE查询,可以显著提升数据库的査询性能。应根据具体场景选择合适的优化策略。

使用EXPLAIN分析查询执行计划,可以确认我们的优化效果。


声明:本站所有内容均为自动采集而来,如有侵权,请联系删除

相关文章

Redis连环五十二问!看谁顶得住?

Redis连环五十二问!看谁顶得住?

基本 1.说说什么是Redis? Redis是一种基于键...

用 PHP 处理 10 亿行数据!

用 PHP 处理 10 亿行数据!

今天,我将带大家一起走进“挑衅十亿行“数据的世界。当然,这个事情是依据GitHub上的一个“十亿行挑衅”(1brc)运动而来,现在正在进行,如果你没有听说过,可查看Gunnar Morlings 的 1brc 存储库。https://github.com/gunnarmorling/1brc我之所以...

2024 年的最佳 PHP 框架

2024 年的最佳 PHP 框架

在本文中,我们将预测在 2024 年持续风行的最佳 PHP 框架。我们首先将看看PHP框架是什么,什么时候该斟酌应用PHP框架,以及应用PHP框架的重要长处都是什么。我还会介绍最合适初学者的 PHP 框架以及用于 Web 开发的最佳框架。什么是PHP框架?     &...

一文读懂多家厂商的大模型训练、推理、部署策略

一文读懂多家厂商的大模型训练、推理、部署策略

4 月 20 日,第 102 期源创会在武汉胜利举行。本期邀请来自武汉人工智能研讨院、华为、MindSpore、京东云、Gitee AI 的人工智能专家,环绕【大模型竞技与性能优化】主题发表演讲。接下来就一起看看本期运动的出色瞬间吧!大合影 get ✅披萨和礼物不能少!接下来进入主题演讲回想环节。可...

请立刻停止编写 Dockerfiles 并使用 docker init

请立刻停止编写 Dockerfiles 并使用 docker init

您是那种认为编写 Dockerfile 和 docker-compose.yml 文件很苦楚的人之一吗?我承认,我就是其中之一。我总是想知道我是否遵守了 Dockerfile、 docker-compose 文件的最佳编写实践,我畏惧在不知不觉中引入了安全破绽。但是现在,我不必再担忧这个问题了,感激...

服务器为什么大多用 Linux 而不是 Windows ?

服务器为什么大多用 Linux 而不是 Windows ?

前几天在知乎看到一个话题很有意思,且很有讨论意义。“服务器为什么大多用 Linux”,除了开源、好用等原因,回答也代表了各种不同人需求和看法,摘取一些分享给大家,也欢迎留言讨论。来自知乎好友“熊大你又骗俺”的回答首先在20年前,windows server+iis+asp+access 的方案,还是...