Oracle根据逗号拆分字段内容转成多行的函数说明

目录
  • 使用场景
  • 1.业务表A
  • 2.实现拆分SQL
  • 3.REGEXP_SUBSTR函数
    • 1)参数说明
    • 2)案例
  • 4.REGEXP_REPLACE函数
    • 1)参数说明
  • 5.CONNECT BY函数
    • 1)基本语法
    • 2)案例
  • 6.LENGTH函数
    • 1)参数说明
    • 2)案例
  • 总结

使用场景

业务表A中一个字段存放用逗号分割的多个业务单元,现在需要将数据转成一个业务单元对应一个数据。

1.业务表A

SELECT * FROM app_template_dept t WHERE t.evaluate_index_code ='3330326';

2.实现拆分SQL

SELECT DISTINCT A.*, REGEXP_SUBSTR(A.DEPT_CODE, '[^,]+', 1, Level, 'i')
  FROM (SELECT *
          FROM APP_TEMPLATE_DEPT T
         WHERE T.EVALUATE_INDEX_CODE = '3330326') A
CONNECT BY Level<= LENGTH(A.DEPT_CODE) -
           LENGTH(REGEXP_REPLACE(A.DEPT_CODE, ',', '')) + 1;

3.REGEXP_SUBSTR函数

对字符串进行正则分割,取特定字符的函数。

1)参数说明

REGEXP_SUBSTR(String, pattern, position, occurrence, modifier)

  • String: 需要进行正则处理的字符串
  • pattern:进行匹配的正则表达式
  • position:起始位置,从第几个字符开始正则表达式匹配(默认为1)
    注意:字符串最初的位置是1而不是0
  • occurrence:标识第几个匹配组,默认为1
    注意:分割后最初的字符串会按分割的顺序排列成组
  • modifier:模式('i’不区分大小写进行检索;‘c’区分大小写进行检索。默认为’c’。)
    注意:针对的是正则表达式里字符大小写的匹配

2)案例

/*从第一个字符开始按照字符'A'(区分大小写)分割字符串'1a2A33a',取第二个分割出来的数据*/
SELECT REGEXP_SUBSTR('1a2A33a','[^A]+',1,2,'c') AS STR FROM DUAL; --结果:33a

SELECT REGEXP_SUBSTR('1a2A33a','[^A]+',1,2,'i') AS STR FROM DUAL; --结果:2

/*把要输出来的第几个子串,通过一个变量ROWNUM转换成输出多少个子串。level<=5代表的是输出5个,没有的为null*/
SELECT REGEXP_SUBSTR('1a2A33a','[^A]+',1,Level,'i') AS STR FROM DUAL CONNECT BY LEVEL<=5; --结果:1、2、33、null、null

4.REGEXP_REPLACE函数

通过正则表达式来进行匹配替换。

1)参数说明

REGEXP_REPLACE(VARCHAR str, VARCHAR pattern, VARCHAR replacement)

str:指定的字符串pattern:被替换的字符串replacement:用于替换的字符串 2)案例

SELECT REGEXP_REPLACE('1a2A33a','A','') AS STR FROM DUAL; --结果:1a233a

5.CONNECT BY函数

一般用来查找存在父子关系的数据,也就是树形结构的数据。

1)基本语法

select ... from
where ... --过滤条件,用于对返回的所有记录进行过滤。
[start with ...] --查询结果重起始根结点的限定条件。
connect by [prior] id=parentid--连接条件
;
  • start with:用来限制第一层的数据,或者叫根节点数据,以这部分数据为基础来查找第二层数据,然后以第二层数据查找第三层数据以此类推。
  • connect by [prior] id=parentid :这部分是用来指明oracle在查找数据时以怎样的一种关系去查找,比如说查找第二层的数据时用第一层数据的id去跟表里面记录的parentid字段进行匹配,如果这个条件成立那么查找出来的数据就是第二层数据,同理查找第三层第四层…等等都是按这样去匹配。

也可以写成connect by id= [prior] parentid,这种用法就表示从下往上查找数据,可以理解为从叶子节点往上查找父级几点,用第一层数据的parentid去跟表记录里面的id进行匹配,匹配成功那么查找出来的就是第二层数据;上面的那种就是从父级节点往下查找叶子节点。

2)案例

select rownum from dual connect by rownum<=10;

结果

select * from table_temp
start with id = '001001'
connect by prior id = parent_id;

table_temp表中数据

结果

6.LENGTH函数

返回字符串表达式中字符数的字符串函数。

1)参数说明

LENGTH(string-expression)

  • string-expression:字符串表达式,可以是列名、字符串文字或另一个标量函数的结果,其中基础数据类型可以表示为任何字符类型(例如 CHAR 或 VARCHAR)

2)案例

SELECT LENGTH('1a2A33a') AS STR FROM DUAL; --结果:7

总结

到此这篇关于Oracle根据逗号拆分字段内容转成多行的文章就介绍到这了,更多相关Oracle逗号拆分字段内容内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Oracle以逗号分隔的字符串拆分为多行数据实例详解

    前言 近期在工作中遇到某表某字段是可扩展数据内容,信息以逗号分隔生成的,现需求要根据此字段数据在其它表查询相关的内容展现出来,第一想法是切割数据,以逗号作为切割符,以下为总结的实现方法,以供大家参考.指教. 1.regexp_substr函数,通过正则来拆分字符串,函数用法为:(必须是oracle 10g+的版本才支持)  REGEXP_SUBSTR函数格式如下: function REGEXP_SUBSTR(String, pattern, position, occurrence, modi

  • Oracle根据逗号拆分字段内容转成多行的函数说明

    目录 使用场景 1.业务表A 2.实现拆分SQL 3.REGEXP_SUBSTR函数 1)参数说明 2)案例 4.REGEXP_REPLACE函数 1)参数说明 5.CONNECT BY函数 1)基本语法 2)案例 6.LENGTH函数 1)参数说明 2)案例 总结 使用场景 业务表A中一个字段存放用逗号分割的多个业务单元,现在需要将数据转成一个业务单元对应一个数据. 1.业务表A SELECT * FROM app_template_dept t WHERE t.evaluate_index_

  • mysql根据逗号将一行数据拆分成多行数据

    目录 分隔效果 命令行解释 涉及函数 分隔效果 -- 分隔前 1,2,3,4 -- 分隔后 1 2 3 4 分隔命令行 SELECT substring_index(substring_index('1,2,3,4',',', b.help_topic_id + 1), ',', -1) result FROM mysql.help_topic b where b.help_topic_id < (LENGTH('1,2,3,4') - LENGTH(REPLACE('1,2,3,4', ','

  • Python如何应用cx_Oracle获取oracle中的clob字段问题

    最近在用Python编写连接数据库获取记录的脚本,其中用到了cx_Oracle模块.它的语法主要如下: cx_Oracle.connect('username','pwd','IP/HOSTNAME:PORT/TNSNAME') import cx_Oracle db1=cx_Oracle.connect('yang','yang','127.0.0.1:1523/yangdb') db2=cx_Oracle.connect('yang/yang@127.0.0.1:1523/yangdb')

  • Python Pandas list列表数据列拆分成多行的方法实现

    1.实现的效果 示例代码: df=pd.DataFrame({'A':[1,2],'B':[[1,2],[1,2]]}) df Out[458]: A B 0 1 [1, 2] 1 2 [1, 2] 拆分成多行的效果: A  B 0  1  1 1  1  2 3  2  1 4  2  2 2.拆分成多行的方法 1)通过apply和pd.Series实现 容易理解,但在性能方面不推荐. df.set_index('A').B.apply(pd.Series).stack().reset_ind

  • pandas实现一行拆分成多行

    目录 一行拆分成多行 1.根据某一列拆分 2.根据多列拆分 一行转多行.多行转一行 1.测试数据 2.一行转多行 3.多行转一行 一行拆分成多行 1.根据某一列拆分 效果: 代码: if __name__ == '__main__': import pandas as pd df = pd.DataFrame({'Country': ['China,US', 'Japan,EU', 'UK,Australia', 'Singapore,Netherland'], 'Number': [100,

  • MySQL更新存放JSON的字段、\“ 转义成 “的问题描述

    目录 问题描述 问题排查 解决方案 本篇介绍在执行MySQL线上变更时遇到的问题,表现为"更新JSON字段时,实际更新的值与SQL语句中的值不一致,JSON格式错误",如下: 问题描述 处理线上问题,需要新插入一条记录:将原JSON粘贴出来,修改部分字段,然后提交SQL更新语句,原始JSON如下: { "playerQualifyType": 1, "surveyId": 14, "playerRegisterEndTime"

  • oracle中读写blob字段的问题解析

    LOB类型分为BLOB和CLOB两种:BLOB即二进制大型对像(Binary Large Object),适用于存贮非文本的字节流数据(如程序.图像.影音等).而CLOB,即字符型大型对像(Character Large Object),则与字符集相关,适于存贮文本型的数据(如歷史档案.大部头著作等). 下面以程序实例说明通过JDBC操纵Oracle数据库LOB类型字段的几种情况. 先建立如下两个测试用的数据库表,Power Designer PD模型如下: 建表SQL语句为:CREATE TA

  • 在WordPress中获取数据库字段内容和添加主题设置菜单

    get_option() 函数使用技巧 get_option()这个函数,实际上我们在整合后台功能的时候经常会用到的一个函数,主要用来从 WordPress 博客数据库 option 表中取得我们想要的字段内容的一个函数,在目前大部分的主题中,只要是主题集成了后台控制页面,也大都用到了这个函数,虽然 WP 给了我们很多方法去临时存储我们对主题的设置,但是用比较稳定的数据库去存储主题设置还是大部分主题作者的首选. get_option() 函数的解释.用法网上还是有很多中文文献的,包括官方文档该函

  • C#实现将类的内容写成JSON格式字符串的方法

    本文实例讲述了C#实现将类的内容写成JSON格式字符串的方法.分享给大家供大家参考.具体如下: 本例中建立了Person类,赋值后将类中内容写入到字符串中 运行本代码需要添加引用动态库Newtonsoft.Json 程序代码: using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; //需要引用 Newtonsoft.Js

  • 使用SQL批量替换语句修改、增加、删除字段内容

    sql替换语句,用该命令可以整批替换某字段的内容,也可以批量在原字段内容上加上或去掉字符. 命令总解:update 表的名称 set 此表要替换的字段名=REPLACE(此表要替换的字段名, '原来内容', '新内容') 如 UPDATE Whir_ProductRelese SET ReleseName=REPLACE(ReleseName,'http://www.maidq.com','http://maidq.com') 举例说明: 1)把backupfile表里url的字段内容里为htt

随机推荐