Mysql LIKE什么时候走索引,什么时候不走索引

在 MySQL 中,LIKE 查询是否走索引,主要取决于通配符的位置和使用的存储引擎。

使用索引的情况

  1. 前缀匹配

    • LIKE 查询中的通配符出现在字符串的末尾时,查询可以利用索引。例如,LIKE 'abc%'
    • 这种情况下,索引可以快速定位以 abc 开头的所有记录,因为索引是按顺序存储的。
    SELECT * FROM table WHERE column LIKE 'abc%';
    
  2. 全匹配

    • LIKE 查询如果没有通配符,等同于 = 查询,也可以利用索引。
    SELECT * FROM table WHERE column LIKE 'abc';
    

不使用索引的情况

  1. 前缀通配符

    • LIKE 查询中的通配符出现在字符串的开头时,查询无法利用索引。例如,LIKE '%abc'LIKE '%abc%'
    • 这种情况下,MySQL 需要扫描整个表来找到匹配的记录,因为无法利用索引进行前缀查找。
    SELECT * FROM table WHERE column LIKE '%abc';
    SELECT * FROM table WHERE column LIKE '%abc%';
    
  2. 中间通配符

    • 当通配符出现在字符串的中间部分时,同样无法利用索引。例如,LIKE 'a%bc'
    SELECT * FROM table WHERE column LIKE 'a%bc';
    

特殊情况

  1. MySQL 5.6 及以后版本的 InnoDB 存储引擎

    • 对于较长的前缀匹配,即使索引的前缀较短,InnoDB 也可以使用索引。为了有效利用索引,可以使用前缀索引。
  2. 字符集和排序规则

    • 索引的使用还取决于列的字符集和排序规则。如果列的字符集和排序规则不一致,可能导致索引无法被正确利用。

示例

-- 能利用索引
CREATE INDEX idx_column ON table (column);
SELECT * FROM table WHERE column LIKE 'abc%';-- 不能利用索引
SELECT * FROM table WHERE column LIKE '%abc';
SELECT * FROM table WHERE column LIKE '%abc%';

优化建议

  1. 前缀索引

    • 对于较长字符串列,可以使用前缀索引。例如,CREATE INDEX idx_column ON table (column(10)); 这样在前 10 个字符上创建索引。
  2. 全文索引

    • 对于需要模糊查询的文本字段,可以考虑使用 MySQL 的全文索引 (FULLTEXT),这在 InnoDB 和 MyISAM 存储引擎中都可以使用。
    CREATE FULLTEXT INDEX idx_column ON table (column);
    SELECT * FROM table WHERE MATCH(column) AGAINST ('search_term');
    

了解这些规则和优化建议,可以帮助你在设计数据库和编写查询时更有效地利用索引,从而提高查询性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/44624.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

文件加密软件谁好用丨2024文件加密软件TOP6推荐

在数字化时代,数据安全已成为企业和个人不可忽视的重要议题。随着数据泄露事件频发,文件加密软件成为了保护敏感信息的首选工具。 本文将为您推荐2024年度最值得信赖的六大文件加密软件,帮助您选择最适合自己需求的加密工具。 1. 域智盾 软…

东方博宜1626 - 暑假的旅游计划

问题描述 期末考试结束了,小华语文、数学、英语三门功课分别考了 x、y、z 分,小华的家长说,如果小华三门功课的平均分在90 分或者 90 分以上,那么就去北京旅游,如果在 90 分以下,那么就去南京玩。 请从键盘…

[linux] git push时需要输入user 和keyword

git clone的要是ssh链接&#xff01;&#xff01;&#xff01;&#xff01; 1、用户名和邮箱 git config --global user.name "name" git config --global user.email "email" 2、生成ssh key (ED25519) ssh-keygen -t ed25519 -C "<自定义内容&g…

手机容器化 安装docker

旧手机-基于Termux容器化 1、安装app 在手机上安装Termux或ZeroTermux&#xff08;Termux扩展&#xff09; 1.1 切换源 注&#xff1a;可以将termux进行换源&#xff0c;最好采用国内源&#xff0c;例如&#xff1a;清华源等 更新包列表和升级包&#xff08;可选&#xff0…

健康云足迹:在iCloud中珍藏您的个人健康检查记录

健康云足迹&#xff1a;在iCloud中珍藏您的个人健康检查记录 随着健康意识的提高&#xff0c;个人健康数据管理变得越来越重要。iCloud作为苹果公司提供的云服务&#xff0c;不仅能够同步您的联系人、日历和照片&#xff0c;还能成为您个人健康检查记录的安全港湾。本文将详细…

数智驱动丨zAIoT 连续落地军工、科研院所和机械制造场景,推动数智化转型升级...

引言 在这个万物互联的时代&#xff0c;科技的进步正以不可阻挡之势&#xff0c;深刻地影响并重塑我们的生产和生活方式。数智化转型升级在各个领域展现出强大的动力&#xff0c;已经成为推动社会向前发展的关键力量。 最近&#xff0c;云和恩墨自主研发的数据智能分析处理平台…

FUSE(用户空间文件系统)命令参数

GPT-4 (OpenAI) FUSE (Filesystem in Userspace)是一个允许创建用户空间文件系统的接口。它提供了一个API&#xff0c;让开发者在未修改内核代码的情况下&#xff0c;通过自己的程序实现文件系统。FUSE 文件系统通常通过 mount 命令来挂载&#xff0c;而且这个命令可以接受各…

时序分解 | Matlab基于ESMD极点对称模态分解

时序分解 | Matlab基于ESMD极点对称模态分解 目录 时序分解 | Matlab基于ESMD极点对称模态分解效果一览基本介绍程序设计参考资料 效果一览 基本介绍 ESMD&#xff08;Extreme-point Symmetric Mode Decomposition&#xff09;是一种信号分解方法&#xff0c;用于提取信号中的模…

【C语言之高级编程】如何将指定变量或函数编译至固定的内存区域中?

如何将指定变量或函数编译至固定的内存区域&#xff1f; 1. 内存类型1.1 bss段&#xff08;Block Started by Symbol&#xff09;1.2 data段&#xff08;data segment&#xff09;1.3 text段&#xff08;code segment/text segment&#xff09;1.4 dec1.5 堆&#xff08;heap&a…

华为模拟器ensp中USG6000V防火墙web界面使用

防火墙需要配置 新建拓扑选择USG6000V型号 在防火墙中导包 忘记截图了 启动设备 输入用户名密码 默认用户名&#xff1a;admin 默认密码&#xff1a;Admin123 修改密码 然后他会提示你是否要修改密码&#xff0c;想改就改不想改就不改 进入命令行界面 进入系统视图开启web…

释放SQL Server潜能:数据库查询性能调优的黄金法则

释放SQL Server潜能&#xff1a;数据库查询性能调优的黄金法则 在企业级应用中&#xff0c;数据库查询性能是影响用户体验和系统效率的关键因素。SQL Server作为微软推出的关系型数据库管理系统&#xff0c;提供了丰富的性能调优工具和策略。本文将深入探讨SQL Server数据库查…

7个外贸网站模板

Nebula独立站wordpress主题 Nebula奈卜尤拉wordpress主题模板&#xff0c;适合搭建外贸独立站使用的wordpress主题。 https://www.jianzhanpress.com/?p7084 Starling师大林WordPress独立站模板 蓝色橙色风格的WordPress独立站模板&#xff0c;适合做对外贸易的外贸公司搭建…

【C++】类和对象--类,实例化,this指针

文章目录 前言一、类1.1 类的定义1.2 类的书写和使用1.3 访问限定符1.4 类域 二、实例化2.1 实例化概念2.2 对象大小 三.this指针总结 前言 前面的几篇文章我们介绍了命名空间&#xff0c;inline&#xff0c;nullptr等C 中常见的的基础概念。今天的文章我们来介绍一些C中类与对…

数据结构 —— BellmanFord算法

数据结构 —— BellmanFord算法 BellmanFord算法检测负权值环BellmanFord和Dijkstra思想上的区别Dijkstra算法的思想Bellman-Ford算法的思想思想上的对比 我们今天来看一个算法BellmanFord算法&#xff0c;我们之前的Dijkstra算法只能用来解决正权图的单源最短路径问题。 Bell…

C语言入门基础题:奇偶 ASCII 值判断(C语言版)和ASCII码表,什么是ASCII码,它的特点和应用?

1.题目描述&#xff1a; 任意输入一个字符&#xff0c;判断其 ASCII 是否是奇数&#xff0c;若是&#xff0c;输出 YES &#xff0c;否则&#xff0c;输出 NO例如&#xff0c;字符 A 的 ASCI 值是 65 &#xff0c;则输出 YES &#xff0c;若输入字符 B(ASCII 值是 66)&#xff…

数据库的学习(5)

题目&#xff1a; 1、新增员工表emp和部门表dept create table dept (deptl int,dept name varchar(11)) charsetutf8; create table emp (sid int,name varchar(11),age int,worktime start date,incoming int,dept2 int) charsetutf8; insert into dept values (101,财务), (…

嵌入式存储突破:STM32与W25Q64 Flash的高效SPI集成

摘要 在嵌入式系统设计中&#xff0c;数据存储解决方案对于确保数据的安全性、可靠性和快速访问至关重要。W25Q64 Flash存储器因其大容量和高效率成为STM32微控制器项目的首选存储设备之一。本文将详细介绍STM32与W25Q64 Flash存储器的高效SPI集成方法&#xff0c;包括硬件设计…

技术探索之kotlin浅谈

Kotlin是一种静态类型编程语言&#xff0c;它运行在Java虚拟机&#xff08;JVM&#xff09;上&#xff0c;可以与Java代码互操作。Kotlin由JetBrains开发&#xff0c;是一种现代、简洁且安全的编程语言。它在2011年首次亮相&#xff0c;2017年被谷歌宣布为Android官方开发语言。…

Matlab中如何添加OptiluX?

1、打开Matlab&#xff0c;依次点击“新建”&#xff0c;“工程”&#xff0c;“从SVN”。 2、存储库路径输入&#xff1a; p/optilux/code - Revision 80: /trunk 同时在“源代码控制集成”菜单中选择“SVN (1.9)” 3、沙盒选择一个自己建的文件夹即可。 来源&#xff1a;Opt…

特征值究竟体现了矩阵的什么特征?

特征值究竟体现了矩阵的什么特征&#xff1f; 简单来说就是x经过矩阵A映射后和自己平行 希尔伯特第一次提出eigenvalue,这里的eigen就是自己的。所以eigenvalue也称作本征值 特征值和特征向量刻画了矩阵变换空间的特征 对平面上的任意向量可以如法炮制&#xff0c;把他在特征…