当前位置: 首页 > news >正文

instr,locate是否使用索引实验

结论:

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,全表扫描)

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

相关文章:

  • DeepSeek【部署 03】客户端应用ChatBox、AnythingLLM及OpenWebUI部署使用详细步骤
  • 并发编程——累加器
  • 【华三】STP端口角色与状态深度解析
  • 仿函数 greater less
  • C++关键字:typename 用于依赖名消歧器(disambiguator)
  • C++进阶知识7 封装map和set
  • 分享能在线运行C语言的网站
  • Bitbucket SSH 访问设置指南
  • Vue3实战学习(Vue环境配置、快速上手及卸载、下载安装Node.js超详细教程(2025)、npm配置淘宝镜像)(1)
  • 常见Web应用源码泄露问题
  • 我的世界1.20.1forge模组开发(8)——自定义实体、AI
  • Hugging Face 推出 FastRTC:实时语音视频应用开发变得得心应手
  • H.264,H.265,H.266标准技术改进
  • 基于字符的卷积网络在文本分类中的应用与探索
  • TypeError: Invalid attempt to spread non-iterable instance
  • 金融合规测试:金融系统稳健运行的“定海神针“
  • Matlab——添加坐标轴虚线网格的方法
  • 本地化deepseek
  • Mybatis如何通过databaseId属性支持不同数据库的不同语法
  • 分布式数据库中的四种透明性:逻辑透明、位置透明、分片透明和复制透明
  • 汕头市营商环境建设监督局网站/企业网站怎么推广
  • 南宁学网站建设/百度网站收录链接提交
  • 网站建设参考网站的说明书/做推广app赚钱的项目
  • 做旅游的网站的要素/最简单的网页制作
  • 天猫做网站/关于seo的行业岗位有哪些
  • 微网站开发框架/廊坊百度快照优化