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
投稿

猜你喜欢

  • 建立三层结构的ASP应用程序

    2009-01-21 19:41:00
  • CSS3的五个使用技巧[译]

    2009-02-19 13:01:00
  • asp如何分页显示数据库查询结果?

    2009-11-22 19:23:00
  • 关于INDEX SERVER+ASP建立查询引擎的一点心得

    2008-03-02 15:56:00
  • 关于从MySQL转向ADODB的方法

    2011-06-02 12:05:00
  • Oracle中查询本月星期5的所有日期列表的语句

    2012-07-11 16:13:21
  • mysql与sqlserver的所有区别

    2009-02-27 16:18:00
  • javascript增加干扰数据实现简单加密效果

    2011-02-24 11:07:00
  • js实时获得服务器上时间

    2008-11-25 13:55:00
  • :hover在IE6下的问题

    2009-06-18 21:09:00
  • 表格可读性提升分析

    2010-05-19 13:03:00
  • 低效的键盘和高效的登录框

    2007-08-22 09:17:00
  • asp 快钱网关接口 支付宝接口 财付通接口代码

    2011-03-08 10:55:00
  • 长期使用中型Access数据库的一点经验

    2007-12-21 13:23:00
  • 带农历及节日的js日历源码

    2010-08-01 17:38:00
  • 利用OBJECT_DEFINITION函数来代码存档

    2009-01-20 15:34:00
  • 一条sql 语句搞定数据库分页

    2009-03-21 18:32:00
  • asp中的rs.open于conn.execute的区别

    2009-10-29 12:12:00
  • 【启发】不用循环计算1到100的和

    2009-03-04 12:16:00
  • 是在客户端确认还是在服务器端确认?

    2010-07-14 21:05:00
  • asp之家 网络编程 m.aspxhome.com