Oracle强制加了hint实效三种连接方式使用场合判断
创始人
2024-05-14 12:12:58
0

开发写了一个语句使用了connect by level函数
SELECT DISTINCT
CTMID FROM
(
SELECT CTMID,
REGEXP_SUBSTR(FLTUSERIDSTR, ‘[^;]+’, 1, l) AS userid
FROM s_userinfo,(SELECT LEVEL l FROM DUAL CONNECT BY LEVEL<=300) b
WHERE l <= LENGTH(FLTUSERIDSTR) - LENGTH(regexp_replace(FLTUSERIDSTR, ‘;’, ‘’)) + 1
)
GROUP BY CTMID, USERID HAVING LENGTH(USERID) > 10;

此语句我添加了hint

SELECT DISTINCT
CTMID FROM
(
SELECT /+use_hash(a,b)/ CTMID,
REGEXP_SUBSTR(FLTUSERIDSTR, ‘[^;]+’, 1, l) AS userid
FROM s_userinfo a,(SELECT LEVEL l FROM DUAL CONNECT BY LEVEL<=300) b
WHERE l <= LENGTH(FLTUSERIDSTR) - LENGTH(regexp_replace(FLTUSERIDSTR, ‘;’, ‘’)) + 1
)
GROUP BY CTMID, USERID HAVING LENGTH(USERID) > 10;

执行计划依旧不会改变
在这里插入图片描述
不能hash的话效率太差20多分钟才能执行完毕
最后采用了use_merge函数
SELECT DISTINCT
CTMID FROM
(
SELECT /+leading(a) use_hash(b)/ CTMID,
REGEXP_SUBSTR(FLTUSERIDSTR, ‘[^;]+’, 1, l) AS userid
FROM s_userinfo a,(SELECT LEVEL l FROM DUAL CONNECT BY LEVEL<=300) b
WHERE l <= LENGTH(FLTUSERIDSTR) - LENGTH(regexp_replace(FLTUSERIDSTR, ‘;’, ‘’)) + 1
)
GROUP BY CTMID, USERID HAVING LENGTH(USERID) > 10;
在这里插入图片描述
七秒钟得到执行效果,速度已经翻了很多倍
最后翻阅文档得出
1.Nested Loops Join支持大于,小于,不等,LIKE等连接条件,可以说没有受到任何限制!
2.Hash Join不支持大于,小于,不等,LIKE等连接条件!
3.Merge Sort Join不支持不等,LIKE等连接条件,却支持大于,小于的连接条件。

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...