MySQL中like模糊查询如何优化?
大家好,我是锋哥。今天分享关于【MySQL中like模糊查询如何优化?】面试题。希望对大家有帮助;
MySQL中like模糊查询如何优化?
1000道 互联网大厂Java工程师 精选面试题-Java资源分享网
在 MySQL 中,LIKE
模糊查询虽然非常常见,但通常会影响查询的性能,尤其是在数据量较大时。为了优化 LIKE
查询,减少查询的开销,可以采取以下几种方法:
1. 使用前缀匹配(避免 %
开头)
-
当
LIKE
查询中模式以%
开头时,MySQL 无法使用索引,因为它无法确定从哪里开始搜索。这会导致全表扫描,从而严重影响性能。不推荐:
SELECT * FROM users WHERE name LIKE '%john';
优化: 如果可能,尽量避免以
%
开头的查询,而是使用前缀匹配。这样 MySQL 可以利用索引进行优化。SELECT * FROM users WHERE name LIKE 'john%';
- 使用前缀匹配时,MySQL 可以利用索引(如果列上有索引),从而加速查询。
2. 使用全文索引(FULLTEXT)
-
如果你的查询模式包含的是大量文本数据,考虑使用 全文索引 (
FULLTEXT
)。这可以显著提高文本搜索的性能,尤其适用于大规模的文本字段搜索。- 适用范围:
CHAR
,VARCHAR
和TEXT
类型的字段。 - 全文索引优化查询时,
MATCH()
和AGAINST()
语法比LIKE
更高效。
创建全文索引:
ALTER TABLE users ADD FULLTEXT(name);
使用全文索引查询:
SELECT * FROM users WHERE MATCH(name) AGAINST ('john' IN NATURAL LANGUAGE MODE);
- 注意:
FULLTEXT
索引适用于自然语言模式或布尔模式的查询,通常能比LIKE
更高效,尤其是在处理大量文本数据时。
- 适用范围:
3. 使用 REGEXP
替代复杂的 LIKE
- 如果你的查询需要进行复杂的模式匹配,
REGEXP
(正则表达式)有时比LIKE
更灵活,虽然在某些情况下性能上也可能较差。为了提高效率,可以优化正则表达式或考虑其他替代方案。
4. 使用索引优化查询
-
为了提高
LIKE
查询的效率,确保查询字段上有索引。如果查询的是一个大表中的字段,创建索引可以显著提升性能。创建索引:
CREATE INDEX idx_name ON users(name);
- 前缀索引:如果你的查询只是检查字段的前几个字符,可以使用前缀索引来优化性能。比如在
VARCHAR(255)
字段上建立一个只索引前 10 个字符的索引。
CREATE INDEX idx_name_prefix ON users(name(10));
- 前缀索引:如果你的查询只是检查字段的前几个字符,可以使用前缀索引来优化性能。比如在
5. 避免使用 LIKE
查询中的通配符 %
- 尽量避免使用
%
通配符,因为它会导致全表扫描。尽量使用明确的查询条件。例如:LIKE 'john%'
比LIKE '%john%'
更容易利用索引,尤其是在大表中。
6. 结合 LEFT()
或 SUBSTRING()
进行字段截取
- 在一些特定的场景中,如果你只需要查询字段的前几个字符,可以使用
LEFT()
或SUBSTRING()
来加速查询。SELECT * FROM users WHERE LEFT(name, 4) = 'john';
- 这种方式可以提高效率,因为它避免了使用
%
通配符。
7. 调整 innodb_ft_min_token_size
(如果使用全文索引)
-
在使用 MySQL 的全文索引时,如果查询内容是短词或者需要查询更短的单词,可以通过调整
innodb_ft_min_token_size
参数来优化全文索引的性能。- 默认情况下,MySQL 对全文索引的最小单词长度有限制(默认值是 4)。你可以将其调整为较小的值来优化查询。
SET GLOBAL innodb_ft_min_token_size = 3;
8. 考虑分表或分区表
- 如果表非常大,考虑对表进行分区或分表处理。这有助于减小查询的范围,从而提高
LIKE
查询的效率。分表或分区能够显著提升特定查询的性能,尤其是在查询时涉及大量数据时。
9. 避免过多的 OR
语句
- 在多个条件的
LIKE
查询中,如果使用多个OR
语句,可能会导致性能问题。可以尝试使用IN
或JOIN
替代多个LIKE
,或者尽量将条件限制在更小的范围内。
总结
LIKE
查询的性能优化主要通过以下几种方式进行:
- 尽量避免使用
%
开头的LIKE
查询。 - 使用全文索引(
FULLTEXT
)来优化文本搜索。 - 使用前缀索引来加速以特定前缀开头的
LIKE
查询。 - 使用正则表达式或其他方法替代复杂的
LIKE
查询。 - 调整数据库配置(如
innodb_ft_min_token_size
)来优化全文索引的使用。
通过这些方法,可以在 MySQL 中对 LIKE
查询进行有效的优化,提升查询效率。
相关文章:

MySQL中like模糊查询如何优化?
大家好,我是锋哥。今天分享关于【MySQL中like模糊查询如何优化?】面试题。希望对大家有帮助; MySQL中like模糊查询如何优化? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在 MySQL 中,LIKE 模糊查询虽然非常常见,…...

用低代码平台集成人工智能:无需专业开发也能实现智能化
引言:人工智能的普及与企业需求 随着人工智能(AI)技术的飞速发展,越来越多的企业开始意识到其在提升运营效率、优化客户体验和推动业务创新方面的巨大潜力。从智能客服到自动化决策支持,从数据分析到个性化推荐&#x…...

【使用hexo模板创建个人博客网站】
使用hexo模板创建个人博客网站 环境准备node安装hexo安装ssh配置 使用hexo命令搭建个人博客网站hexo命令 部署到github创建仓库修改_config.yml文件 编写博客主题扩展 环境准备 node安装 进入node官网安装node.js 使用node -v检查是否安装成功 安装成功后应该出现如上界面 …...

最简单圆形进度条实现CSS+javascript,两端带圆弧
两端是弧形的圆形进度条。 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>Document</title…...

vuejs 模板语法、条件渲染、v-for、事件处理、表单输入绑定
创建vue项目之后我们就可以开始写代码了,我们的代码一般都会写在src目录-components目录-HelloWord.vue文件内。 我们之前写的HTML文件的结构是HTML代码可以集成或者连接外部的css/js文件。 我们通过vue建立的项目,它的结构是在一个vue文件内集成了HTML…...
论文阅读方法
文章目录 步骤一:对论文进行自我判断阅读题目和关键词。阅读摘要阅读总结要点 步骤二:阅读文章阅读图表和图表的注释阅读引言阅读实验部分阅读结果和作者对结果的讨论(创新点)要点 步骤三:精度论文回答问题1回答问题2回…...
问题解决:Kali Linux 中配置启用 Vim 复制粘贴功能
在 Kali Linux 系统中,使用 XShell 或其他类似终端时,Vim 编辑器的默认设置并不支持直接进行复制和粘贴操作,这对于日常的开发工作或渗透测试人员来说可能会造成不便。幸运的是,通过简单的配置调整,可以让 Vim 轻松支持…...
Linux hexdump命令
hexdump 是 Linux 中一个强大的二进制文件查看工具,可以用于查看文件的十六进制、ASCII 或其他格式的转储内容。以下是常见用法及示例: 1. 查看文件头部(前 N 个字节) 语法 hexdump -n <字节数> -C <文件名>示例&am…...

Stable Diffusion教程|快速入门SD绘画原理与安装
什么是Stable Diffusion,什么是炼丹师?根据市场研究机构预测,到2025年全球AI绘画市场规模将达到100亿美元,其中Stable Diffusion(简称SD)作为一种先进的图像生成技术之一,市场份额也在不断增长&…...

系统架构设计师—系统架构设计篇—微服务架构
文章目录 概述优势挑战 概述 微服务是一种架构风格,将单体应用划分成一组小的服务,服务之间相互协作,实现业务功能,每个服务运营在独立的进程中,服务间采用轻量级的通信机制协作(通常是HTTP/JSON࿰…...
Array and string offset access syntax with curly braces is deprecated
警告信息 “Array and string offset access syntax with curly braces is deprecated” 是 PHP 中的一个弃用警告(Deprecation Notice),表明在 PHP 中使用花括号 {} 来访问数组或字符串的偏移量已经被标记为过时。 背景 在 PHP 的早期版本…...

腾讯元宝:AI 时代的快速论文阅读助手
1. 背景与需求 在 AI 研究领域,每天都会涌现大量学术论文。如何高效阅读并提取关键信息成为研究者的一大难题。腾讯元宝是腾讯推出的一款大模型,结合了**大语言模型(LLM)和自然语言处理(NLP)**技术&#x…...
基于单片机的风速报警装置设计
标题:基于单片机的风速报警装置设计 内容:1.摘要 本设计聚焦于基于单片机的风速报警装置,旨在解决传统风速监测缺乏实时报警功能的问题。采用单片机作为核心控制单元,结合风速传感器采集风速数据。经实验测试,该装置能准确测量 0 - 60m/s 范…...

1998-2022年各地级市第一产业占GDP比重/地级市第一产业占比数据(市辖区)
1998-2022年各地级市第一产业占GDP比重/地级市第一产业占比数据(市辖区) 1、时间:1998-2022年 2、指标:地级市第一产业占GDP比重/地级市第一产业占比 3、来源:城市统计年鉴 4、范围:299个地级市 5、缺…...

IntersectionObserver接口介绍
IntersectionObserver API 是浏览器提供的一个用于异步观察目标元素与其祖先元素或视口(Viewport)交叉状态(即是否进入或离开视口)的接口。在 IntersectionObserver 出现之前,开发者通常需要通过监听 scroll 事件或使用…...
go并发学习笔记
包含了go学习笔记,含有channel的基础学习,编写数字的平方,如何成组的合并channel,如何优雅的关闭退出并发协程,通道阻塞情况分析,channel与哪些变成情况,可谓是收藏好文. 文章目录 并发1:chann…...

DeepSeek V3 源码:从入门到放弃!
从入门到放弃 花了几天时间,看懂了DeepSeek V3 源码的逻辑。源码的逻辑是不难的,但为什么模型结构需要这样设计,为什么参数需要这样设置呢?知其然,但不知其所以然。除了模型结构以外,模型的训练数据、训练…...
关于C++数据类型char的类型是整数的思考
学习数据类型时,整数类型中有一个特殊的类型char,可以使用字符来为其赋,也可以用整数来为其赋值,这是怎么一回事?其实任何类型,在计算机的内存中,在最小的存储单元比特中,内部只有0或…...

手写识别革命:Manus AI如何攻克多语言混合识别难题(二)
一、多语种特征分离:对抗训练与解耦表示 1. 梯度反转层(GRL)实现语言无关特征提取 class GradientReversalFn(Function):staticmethoddef forward(ctx, x, alpha):ctx.alpha alphareturn x.view_as(x)staticmethoddef backward(ctx, grad_…...

windows:curl: (60) schannel: SEC_E_UNTRUSTED_ROOT (0x80090325)
目录 1. git update-git-for-windows 报错2. 解决方案2.1. 更新 CA 证书库2.2. 使用 SSH 连接(推荐)2.3 禁用 SSL 验证(不推荐) 1. git update-git-for-windows 报错 LenovoLAPTOP-EQKBL89E MINGW64 /d/YHProjects/omni-channel-…...

使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...

LeetCode - 394. 字符串解码
题目 394. 字符串解码 - 力扣(LeetCode) 思路 使用两个栈:一个存储重复次数,一个存储字符串 遍历输入字符串: 数字处理:遇到数字时,累积计算重复次数左括号处理:保存当前状态&a…...

基于Docker Compose部署Java微服务项目
一. 创建根项目 根项目(父项目)主要用于依赖管理 一些需要注意的点: 打包方式需要为 pom<modules>里需要注册子模块不要引入maven的打包插件,否则打包时会出问题 <?xml version"1.0" encoding"UTF-8…...

Linux-07 ubuntu 的 chrome 启动不了
文章目录 问题原因解决步骤一、卸载旧版chrome二、重新安装chorme三、启动不了,报错如下四、启动不了,解决如下 总结 问题原因 在应用中可以看到chrome,但是打不开(说明:原来的ubuntu系统出问题了,这个是备用的硬盘&a…...
JDK 17 新特性
#JDK 17 新特性 /**************** 文本块 *****************/ python/scala中早就支持,不稀奇 String json “”" { “name”: “Java”, “version”: 17 } “”"; /**************** Switch 语句 -> 表达式 *****************/ 挺好的ÿ…...

自然语言处理——Transformer
自然语言处理——Transformer 自注意力机制多头注意力机制Transformer 虽然循环神经网络可以对具有序列特性的数据非常有效,它能挖掘数据中的时序信息以及语义信息,但是它有一个很大的缺陷——很难并行化。 我们可以考虑用CNN来替代RNN,但是…...

Linux --进程控制
本文从以下五个方面来初步认识进程控制: 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程,创建出来的进程就是子进程,原来的进程为父进程。…...

C++使用 new 来创建动态数组
问题: 不能使用变量定义数组大小 原因: 这是因为数组在内存中是连续存储的,编译器需要在编译阶段就确定数组的大小,以便正确地分配内存空间。如果允许使用变量来定义数组的大小,那么编译器就无法在编译时确定数组的大…...

佰力博科技与您探讨热释电测量的几种方法
热释电的测量主要涉及热释电系数的测定,这是表征热释电材料性能的重要参数。热释电系数的测量方法主要包括静态法、动态法和积分电荷法。其中,积分电荷法最为常用,其原理是通过测量在电容器上积累的热释电电荷,从而确定热释电系数…...

保姆级教程:在无网络无显卡的Windows电脑的vscode本地部署deepseek
文章目录 1 前言2 部署流程2.1 准备工作2.2 Ollama2.2.1 使用有网络的电脑下载Ollama2.2.2 安装Ollama(有网络的电脑)2.2.3 安装Ollama(无网络的电脑)2.2.4 安装验证2.2.5 修改大模型安装位置2.2.6 下载Deepseek模型 2.3 将deepse…...