oracle 字符串转成行

来源:asp之家 时间:2009-06-19 17:38:00 

SELECT   SUBSTR (T.RPT_ID,
               INSTR (T.RPT_ID,',',1,C.LV)+ 1,
               INSTR (T.RPT_ID,',',1,C.LV + 1)- (INSTR (T.RPT_ID,',',1,C.LV)+ 1))
           AS RPT_ID
 FROM   (SELECT ',' || '85,86,87' || ',' RPT_ID,
                LENGTH ('85,86,87' || ',') - NVL (LENGTH (REPLACE ('85,86', ',')), 0) CNT
           FROM DUAL) t,
        (SELECT LEVEL lv
           FROM DUAL
         CONNECT BY LEVEL <= LENGTH('85,86,87' || ',') - NVL(LENGTH(REPLACE('85,86,87', ',')), 0)) c
WHERE   T.cnt >= c.lv
说明:CNT表示串里面有多少字符。
当是字符串是表中的字段时,取level<=最大个数
如:
1).取最大个数
SELECT MAX(LENGTH(RPT_ID || ',') -
           NVL(LENGTH(REPLACE(RPT_ID, ',')), 0)) INTO v_c
   FROM DIM_AUDIT_TABLE@sjmh_inter;
2).l转成行
SELECT T.T_NAME,
                      T.T_NAME_COMM,
                      T.T_COLUMN,
                      T.T_COLUMN_COMM,
                      t.COMMENT_NL,
                      t.COMMENT_NL_TIME,
                      t.SEQ_USER_ID,
                      SUBSTR(T.RPT_ID,
                             INSTR(T.RPT_ID, '','', 1, C.LV) + 1,
                             INSTR(T.RPT_ID, '','', 1, C.LV + 1) -
                             (INSTR(T.RPT_ID, '','', 1, C.LV) + 1)) AS RPT_ID
                 FROM (SELECT A.T_NAME,
                              A.T_NAME_COMM,
                              A.T_COLUMN,
                              A.T_COLUMN_COMM,
                              a.COMMENT_NL,
                              a.COMMENT_NL_TIME,
                              a.SEQ_USER_ID,
                              '','' || A.RPT_ID || '','' RPT_ID,
                              LENGTH(A.RPT_ID || '','') -
                              NVL(LENGTH(REPLACE(A.RPT_ID, '','')), 0) CNT
                         FROM DIM_AUDIT_TABLE@sjmh_inter A
                        WHERE a.COMMENT_NL is not null) T,
                      (SELECT LEVEL LV FROM DUAL CONNECT BY LEVEL <= '||v_c||') C
                WHERE C.LV <= T.CNT;

注:如果是上面代码是远程的代码,(SELECT LEVEL LV FROM DUAL CONNECT BY LEVEL <= '||v_c||') C,不要用dual表,可以改用all_objects或user_objects, 要不然能查询,但是把查询出来的SQL插入到某个表时,只能插入一行

标签:oracle,字符串,转成行
0
投稿

猜你喜欢

  • 基于SQLAlchemy实现操作MySQL并执行原生sql语句

    2024-01-18 17:16:05
  • Python3.10 Generator生成器Coroutine原生协程详解

    2023-10-25 15:31:36
  • Python绘制1000响大地红鞭炮动态效果

    2021-08-21 20:44:26
  • tensorflow-gpu安装的常见问题及解决方案

    2021-08-18 11:31:18
  • 讲解SQL Server数据库的触发器安全隐患

    2009-01-13 14:01:00
  • python中xrange和range的区别

    2023-03-14 05:54:35
  • 浅析DW4中的站点管理

    2007-02-03 11:40:00
  • 制作设置404页面

    2009-07-03 13:01:00
  • BP神经网络原理及Python实现代码

    2022-09-04 21:12:24
  • python OpenCV的imread不能读取中文路径问题及解决

    2022-10-03 07:41:39
  • go获取协程(goroutine)号的实例

    2024-05-29 22:07:21
  • python 文件读写和数据清洗

    2021-02-10 22:58:43
  • python利用pd.cut()和pd.qcut()对数据进行分箱操作

    2022-03-26 07:57:45
  • chatGPT使用及注册过程中常见的一些错误解决方法(所有报错汇总)

    2023-03-02 22:27:23
  • NumPy中的维度Axis详解

    2021-02-12 12:39:35
  • Python利用docx模块实现快速操作word文件

    2022-06-19 07:18:45
  • 关于Java中使用jdbc连接数据库中文出现乱码的问题

    2024-01-28 14:57:24
  • 浅谈MySQL8.0 异步复制的三种方式

    2024-01-29 00:26:46
  • 关于数据库的alter table操作和索引概念

    2009-12-15 21:57:00
  • Python获取二维矩阵每列最大值的方法

    2022-08-28 00:26:16
  • asp之家 网络编程 m.aspxhome.com