当前位置:首页 > 技术分析 > 正文内容

5种优化方法:MySQL的Like查询(mysql查询语句like)

ruisui884个月前 (02-03)技术分析24

昨天,一个朋友在面试中被面试官问到了这么个问题:MySQL中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分析查询执行计划,可以确认我们的优化效果。

扫描二维码推送至手机访问。

版权声明:本文由ruisui88发布,如需转载请注明出处。

本文链接:http://www.ruisui88.com/post/1054.html

标签: 查询优化
分享给朋友:

“5种优化方法:MySQL的Like查询(mysql查询语句like)” 的相关文章

Vue.js 组件通信的 3 大妙招

在 Vue.js 中,组件化是其核心概念之一,允许你将复杂的界面拆分成多个独立的、可复用的组件。在构建大型应用时,如何高效地在组件之间传递数据和触发事件是非常重要的。Vue.js 提供了多种方式来处理组件间的通信,下面是最常用的 3 种方式:1.父子组件通信:通过 Props 和 Events在 V...

软件测试-性能测试专题方法与经验总结

本文 从 性能测试流程,性能测试指标,性能监测工具,性能测试工具,性能测试基线,性能测试策略,性能瓶颈分析方法几个维度,进行知识总结和经验分享;详细见下图总结,欢迎大家补充;性能测试经验与思考1. 性能测试流程1.1. 性格规格评审1.2. 资源排期1.2.1. 人力资源1.2.2. 时间计划· 性...

高效使用 Vim 编辑器的 10 个技巧

在 Reverb,我们使用 MacVim 来标准化开发环境,使配对更容易,并提高效率。当我开始使用 Reverb 时,我以前从未使用过 Vim。我花了几个星期才开始感到舒服,但如果没有这样的提示,可能需要几个月的时间。这里有十个技巧可以帮助你在学习使用 Vim 时提高效率。1. 通过提高按键重复率来...

学前端,这30个CSS选择器,你必须熟记

你学会了基本的id,class类选择器和descendant后代选择器,然后就觉得完事了吗?如果这样,你就会错过许多灵活运用CSS的机会。虽然本文提到的许多选择器都属于CSS3,并且只能在现代的浏览器中使用,但学会这些是大有好处的。什么是CSS选择器呢?每一条css样式定义由两部分组成,形式如下:[...

VUE-router

七.Vue-router1、什么是vue-routervue-router是vue.js官方路由管理器。vue的单页应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来。传统页面切换是用超链接a标签进行切换。但vue里是用路由,因为我们用Vue做的都是单页应用,就相当于只有一个主的i...

三、Uni-app + vue3 页面如何跳转及传参?

Vue 项目往往需要使用 vue-router 插件,刚开始入门 Uni-app + Vue3 项目的同学,会不会想着路由使用 vue-router V4 版本不就可以了吗?不怕大家笑话,我就是这样想的,毕竟我是第一次使用 Uni-app ,由于孕期记性贼差,所以我决定写成笔记,加深记忆。uni-a...