【更新中】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' 的记录,因为它不知道从索引的哪个位置开始查找,需要遍历很多可能的记录。

相关推荐
Watink Cpper9 分钟前
[MySQL初阶]MySQL(8)索引机制:下
android·数据库·b树·mysql·b+树·myisam·innodedb
苹果酱056726 分钟前
SpringCloud第二篇:注册中心Eureka
java·vue.js·spring boot·mysql·课程设计
freejackman27 分钟前
MySQL 基础入门
数据库·后端·sql·mysql
二年级程序员1 小时前
SQL语句(一)—— DDL
数据库·sql·mysql
邴越1 小时前
不同向量数据库(FAISS / Pinecone / Weaviate)在 RAG 中的优缺点
数据库·faiss
Allen Bright1 小时前
【MySQL基础-21】MySQL事务机制详解:原理、实现与最佳实践
数据库·mysql
movie__movie1 小时前
Spring AI MCP 客户端实战:轻松连接高德地图等工具
数据库·人工智能·spring
清风19811 小时前
kafka消息可靠性传输语义
数据库·分布式·kafka
数据智能老司机3 小时前
CockroachDB权威指南——SQL调优
数据库·分布式·架构
数据智能老司机3 小时前
CockroachDB权威指南——应用设计与实现
数据库·分布式·架构