news 2026/6/12 5:52:40

like关联改写

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
like关联改写

1、 等价转换
instr:字符串查找函数

INSTR(string,substring [,start_position [,occurrence [,return_option]]])string:源字符串substring:要查找的子串start_position:可选,开始搜索的位置(默认1,负数表示从末尾开始)occurrence:可选,指定查找第几次出现(默认1)return_option:可选,0=返回子串起始位置,1=返回子串结束位置

substr: 字符串截取函数

SUBSTR(string,start_position [,length])string:源字符串start_position:开始位置(正数从开头,负数从末尾)length:可选,要截取的长度(默认到字符串结尾)

LIKE:模糊匹配
其三者之间的转换

2、 问题语句

这里问题在于驱动表为t2,index join次数100万次,前面说过与substr和instr可以等价转换,这里想要转换驱动表,那么就需要用substr。
3、 改写

这里与预期的一样驱动表变为t1表,index join次数降下来,另外注意的是,susbtr获取定长的情况下才做index join,因此这里结合业务可以知道是获取4个字节长度。执行时间从原来的10s下降到0.5s
如果是不定长,大家可以感受一下

这里没有做成index join,而是做成nest loop,反而效率下降了。

4、 小结

(1)Like、substr和instr之间可以相互转换。
(2)substr获取是定长的字符串时可以利用索引做索引连接。
(3)性能优化改写主要是针对问题去找到更加高效的方法去实现。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 2:19:42

基于单片机的家庭防盗防火智能门窗报警系统设计

基于单片机的家庭防盗防火智能门窗报警系统设计概述 点击链接下载设计资料:https://download.csdn.net/download/m0_51061483/92081458 1.1 研究背景与设计意义 随着城市化进程的不断推进和居民生活水平的提高,家庭住宅的安全问题日益受到关注。入室盗…

作者头像 李华
网站建设 2026/6/10 23:46:12

centos7:离线安装docker

文章目录 centos7:离线安装docker一、查看centos7的版本和架构二、下载docker二进制静态二进制文件三、上传并解压到服务器四、将二进制文件复制到系统目录五、配置Docker系统服务(关键步骤)六、启动并启用Docker服务七、卸载步骤 centos7&am…

作者头像 李华
网站建设 2026/6/10 15:35:55

一文详解Java中Thread、ThreadGroup 和 ThreadLocal<T> 三者的区别和用途

01-Thread (线程)1.1 核心含义Thread是Java中表示和管理“线程”本⾝的类;⼀个Thread对象就对应着⼀条独⽴的执⾏路径1.2 主要作用并发执行:允许程序同时运⾏多个任务,提⾼资源利⽤率和响应速度 封装任务:将需要并发执⾏的代码封装…

作者头像 李华
网站建设 2026/6/11 16:24:09

【time-rs】time库 ComponentRange 错误类型详解(error/component_range.rs)

这是一个 Rust 时间库中的组件范围错误类型,用于表示时间组件(如年、月、日、时、分、秒等)值超出允许范围的情况。 1. 结构体定义 pub struct ComponentRange {pub(crate) name: &static str, // 组件名称pub(crate) minimum: i64…

作者头像 李华