当前位置: 首页 > 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,全表扫描)

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

http://www.dtcms.com/a/56260.html

相关文章:

  • 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属性支持不同数据库的不同语法
  • 分布式数据库中的四种透明性:逻辑透明、位置透明、分片透明和复制透明
  • ⭐算法OJ⭐N-皇后问题 II【回溯剪枝】(C++实现)N-Queens II
  • Spring中的@Qualifier和@Resource注解有什么不同?
  • redis 支持哪几种数据结构
  • 【FPGA开发】Verilog-数据截断实现四舍五入效果、模块化改造、对比Matlab验证,Modelsim覆盖率
  • SSLScan实战指南:全面检测SSL/TLS安全配置
  • 股指期货交割日每月几号?为什么是第三个周五还是倒数第二个周五?
  • 第十五届蓝桥杯Scratch12月stema选拔赛真题—消失的水母
  • STM32之Unix时间戳
  • 计算机毕业设计Python+DeepSeek-R1大模型医疗问答系统 知识图谱健康膳食推荐系统 食谱推荐系统 医疗大数据(源码+LW文档+PPT+讲解)
  • Spring-framework源码编译