instr,locate是否使用索引实验

发布于:2025-03-10 ⋅ 阅读:(20) ⋅ 点赞:(0)

结论:

instr跟locate不会走索引

个人认为的原因:

1:函数会导致索引失效。这俩是函数

2:专业的模糊查询like百分号开头都是全表扫描,这俩业余的为什么就可以比专业的like更好用?

1:传统方式(掠过,%开头不走,反之走)

2:instr(mysql索引的)

查找一个字符串在另一个字符串中首次出现的位置

(只用模糊查询不考虑哪一位开始,写死>0)

=0没找到

  • = 0:表示没有找到子串。也就是说,在主串中不存在指定的子串。

> 0找到了

  • > 0:表示找到了子串,并且返回值是子串在主串中首次出现的起始位置。例如,如果 INSTR('abcdef', 'bc') 返回 2,这意味着“bc”是从主串“abcdef”的第二个字符开始的。

= 1 , = 2, = 3只查找指定下标位出现的数据

SELECT INSTR('abcdef', 'bc'); -- 返回 2
SELECT INSTR('abcdef', 'a');  -- 返回 1
SELECT INSTR('abcdef', 'f');  -- 返回 6
SELECT INSTR('abcdef', 'z');  -- 返回 0,因为 'z' 不在 'abcdef' 中

-- 查询起始位置是前端的数据
SELECT *
FROM your_table
WHERE INSTR(your_column, '【前端】') = 1;

-- 查询第二位是前端的数据
SELECT *
FROM your_table
WHERE INSTR(your_column, '【前端】') = 1;
【前端】bcd会被匹配到  ABC【前端】匹配不到

LOCATE

LOCATE 函数(在MySQL中)用于查找一个子字符串在另一个字符串中的起始位置。

它返回的是子字符串首次出现的位置索引,

如果未找到该子字符串,则返回0。

假设我们有以下数据行:

【前端】xxxx
abc【前端】def
no match here

题目1:
查找是否以“【前端】”开头
使用 LOCATE('【前端】', column_name) = 1 可以检查列中的值是否以“【前端】”开头。
SELECT *
FROM your_table
WHERE LOCATE('【前端】', column_name) = 1;

题目2:
查找是否包含“【前端】”
SELECT *
FROM your_table
WHERE LOCATE('【前端】', column_name) > 0;
找所有包含“【前端】”的记录,无论它位于字符串的哪个位置,可以使用 LOCATE('【前端】', column_name) > 0。

是否使用索引的实验:

表索引如下:

传统方式不以%开头

EXPLAN结果(rang,索引范围扫描)

INSTR

EXPLAN结果(ALL,全表扫描)

LOCATE

EXPLAN结果(ALL,全表扫描)

==========================================