码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • oracle使用regexp_substr来拆分,CONNECT BY LEVEL查询卡死,速度慢的问题。


    一、问题

    oracle 使用regexp_substr+CONNECT BY LEVEL来,根据特定字符拆分成多行。
    (注意这里我的数据是每个值都有“ ; ”,即使后面没有值,后面也会有个“ ; ”, 如果是正常的分隔符,sql 需要改成” LEVEL < = regexp_count(name, ‘;’)+1 ”)

    select distinct regexp_substr(name, '[^;]+', 1, LEVEL) name
      from (select distinct name
              from table_name a
             where TIME1 > sysdate - 1 / 24)
    CONNECT BY LEVEL < = regexp_count(name, ';');
    
    • 1
    • 2
    • 3
    • 4
    • 5

    执行后发现特别慢,查询了好几分钟没没出来。
    如果单独拿select distinct name
    from table_name a
    where TIME1 > sysdate - 1 / 24
    查询,发现挺快的。
    查看下执行计划在这里插入图片描述

    二、解决方法

    调整后。通过利用rownum 进行join ,sql:

    select distinct regexp_substr(name, '[^;]+', 1, n) name
      from (select  
            distinct name, regexp_count(name, ';') rn
              from table_name a
             where TIME1 > sysdate - 1)
     join (SELECT rownum n from table_name a where rownum <= 999)
        on n <= rn
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    (rownum <= 999可以改成rownum <=(select max(regexp_count(name, ‘;’)) from table_name where TIME1 > sysdate - 1) )
    注意:
    这个里table_name表的总行数,需要比(select max(regexp_count(name, ‘;’)) from table_name where TIME1 > sysdate - 1) 大。如果没有,随便拿个比较大的表替代,不可使用(SELECT LEVEL n FROM DUAL CONNECT BY LEVEL <= 99)替代。

    执行计划:
    在这里插入图片描述
    查询耗时只需要2s多
    在这里插入图片描述

    三、总结

    CONNECT BY是层次查询,一般用来构造树形的构造,这里查询不太适用。通过rownum构造虚拟的表,进行jion查询,执行计划就会执行MERGE JOIN 进行关联,效率将会大大提高 。

  • 相关阅读:
    NVIDIA Jetson之磁盘空间优化方法
    电脑翻译软件-在线电脑实时翻译软件
    Java连接数据库并查询表中的全部数据
    【web-攻击后端组件】(7.1)注入操作系统命令:Perl、ASP、动态执行、OS命令注入
    RENAME,CHANGE,ALTER,MODIFY 四个字段的作用和区别
    基于JAVA物流公司停车位管理计算机毕业设计源码+系统+mysql数据库+lw文档+部署
    子组件自定义事件$emit实现新页面弹窗关闭之后父界面刷新
    paddle动态图自定义算子(python版)
    [AGC058C]Planar Tree
    RocketMQ笔记-进行中
  • 原文地址:https://blog.csdn.net/qq_39255840/article/details/134269109
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号