【更新中】Mysql问题分析

WHERE条件包含 LIKE CONCAT('%',..., '%') 的情况

使用场景影响索引利用情况

当CONCAT函数用于构建一个完整的、固定值(如CONCAT('fixed_prefix', column_name)或CONCAT(column_name, 'fixed_suffix')),并且在WHERE子句中作为比较条件时,如果相关列有合适的索引,是有可能利用索引的。因为数据库可以根据索引的有序性,从索引中定位到符合固定前缀或后缀开头(结尾)的记录范围。

例如,有一个表users,其中有一个name列并建立了索引,查询SELECT * FROM users WHERE name LIKE CONCAT('J', '%')(这里CONCAT用于构建一个以 'J' 开头的模式),数据库可能会利用索引来定位以 'J' 开头的记录范围,而不是进行全表扫描。

模糊匹配场景难以利用索引

当CONCAT与LIKE操作符结合,且在LIKE表达式中两端都带有通配符(如LIKE CONCAT('%', column_name, '%'))时,通常无法有效利用索引。这是因为索引是按照一定的顺序存储数据的,这种两边都不确定的模糊匹配方式,使得数据库很难通过索引快速定位符合条件的数据,往往需要对大量数据进行扫描和匹配。

例如,对于查询SELECT * FROM users WHERE name LIKE CONCAT('%', 'John', '%'),数据库很难利用索引来高效地找到包含 'John' 的记录,因为它不知道从索引的哪个位置开始查找,需要遍历很多可能的记录。

相关推荐
Linux运维技术栈6 小时前
生产环境资源占用过高排查实战:从Heap Dump到全链路优化
java·服务器·网络·数据库·程序
jackletter6 小时前
五大关系数据库(sqlserver、mysql、oracle、pgsql、sqlite)如何结合c#存取时间
mysql·oracle·sqlserver
不想画图6 小时前
数据库概念和编译安装mysql流程
linux·数据库·mysql
默恋~微凉6 小时前
数据库与安装
数据库
沐雨风栉6 小时前
被局域网困住的文件?cpolar让 Go File 随时随地能用
运维·服务器·开发语言·数据库·后端·缓存·golang
e***87706 小时前
【Redis】centos7 systemctl 启动 Redis 失败
数据库·redis·缓存
徐同保6 小时前
n8n项目node后端sqlite相关的
java·数据库·sqlite
一点事6 小时前
oracle:创建表空间、用户和授权
数据库·oracle
w***95496 小时前
运维实战---多种方式在Linux中部署并初始化MySQL
linux·运维·mysql
w***74406 小时前
使用python进行PostgreSQL 数据库连接
数据库·python·postgresql