码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Oracle中分割字符串的方法


    Oracle中分割字符串的方法

    • 1. 使用 regexp_substr() 函数
      • 1.1 方式1
      • 1.2 方式2
      • 1.3 注意问题(尤其是存储过程中用到,可能会入坑)
    • 2. 自定义函数
      • 2.1 自定义类型 table
      • 2.2 自定义函数
        • 2.2.1 自定义函数
        • 2.2.2 效果如下:
      • 2.3 Oracle查看<Collection> 类型数据
    • 3.

    1. 使用 regexp_substr() 函数

    1.1 方式1

    • 如下:
      select regexp_substr('bbb,aaa,ccc', '[^,]+', 1, level) as split_result
        from dual
      connect by level <=
                 length('bbb,aaa,ccc') - length(replace('bbb,aaa,ccc', ',')) + 1;
      
      • 1
      • 2
      • 3
      • 4
      在这里插入图片描述

    1.2 方式2

    • 如下:

      select regexp_substr(replace('aaa;bbb;ccb', '', ';'), '[^;]+', 1, level) as split_result
         from dual
       connect by level <= regexp_count('aaa;bb;', ';') + 1;
      
      • 1
      • 2
      • 3

      在这里插入图片描述

      或者 with 写法,如下

      with temp as
       (select 'bbb,aaa,ccc' as str from dual)
      select regexp_substr(replace(str, ',', ' ,'), '[^,]+', 1, level)
        from temp
      connect by level <= regexp_count(str, ',') + 1
      
      • 1
      • 2
      • 3
      • 4
      • 5

      在这里插入图片描述

    1.3 注意问题(尤其是存储过程中用到,可能会入坑)

    • 问题情况(可能会出现空行),如下:
      在这里插入图片描述
      在这里插入图片描述

    • 解决问题:
      上述空行不是我们所需要的,所以排除即可,如下:

      select split_result,length(split_result) from (
       select regexp_substr(replace('aaa;bb;', '', ';'), '[^;]+', 1, level) as split_result
         from dual
       connect by level <= regexp_count('aaa;bb;', ';') + 1)
       where split_result is not null;
      
      • 1
      • 2
      • 3
      • 4
      • 5

      在这里插入图片描述
      在这里插入图片描述

    2. 自定义函数

    2.1 自定义类型 table

    • 如下:
      create or replace type result_split_list as table of varchar2(100);
      
      • 1

    2.2 自定义函数

    2.2.1 自定义函数

    • 如下:
      create or replace function split_strs(strs varchar2, type_split varchar2)
        return result_split_list
        pipelined is
        index_num  pls_integer;
        str_list varchar2(100) := strs;
      begin
        loop
          index_num := instr(str_list, type_split);
          if index_num > 0 then
            pipe row(substr(str_list, 1, index_num - 1));
            str_list := substr(str_list, index_num + length(type_split));
          else
            pipe row(str_list);
            exit;
          end if;
        end loop;
        return;
      end split_strs;
      
      • 1
      • 2
      • 3
      • 4
      • 5
      • 6
      • 7
      • 8
      • 9
      • 10
      • 11
      • 12
      • 13
      • 14
      • 15
      • 16
      • 17
      • 18
      在这里插入图片描述

    2.2.2 效果如下:

    • 如下:
      在这里插入图片描述
      在这里插入图片描述

    2.3 Oracle查看<Collection> 类型数据

    • 上面的效果我们看到查看到的是<Collection> 类型,不方便查看数据,处理如下:
      select * from table (select split_strs('aaa,bbb,ccc',',') from dual);
      
      • 1
      在这里插入图片描述

    3.

  • 相关阅读:
    【pytest】 pytest拓展功能 pycharm PermissionError: [Errno 13] Permission denied:
    java毕业设计—— 基于java+JavaEE+jsp的售后服务管理系统设计与实现(毕业论文+程序源码)——售后服务管理系统
    MySQL 用 BETWEEN AND 日期查询包含范围边界
    Matlab:数据分析与多项式计算
    零基础学Python之数据类型的转换(手把手带你做牛客网python代码练习题)
    postman教程-13-关联接口调用
    R3LIVE代码详解(四)
    vscode 连接ubuntu git下载缓慢
    【使用typedef将复杂的block定义简化 Objective-C语言】
    移动硬盘误删除要如何恢复呢?
  • 原文地址:https://blog.csdn.net/suixinfeixiangfei/article/details/127577820
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号