美文网首页
Oracle 行转列

Oracle 行转列

作者: SpinachC | 来源:发表于2018-07-12 17:15 被阅读5次
  1. 行转列,以, 分隔
SELECT regexp_substr(你要转的字符串,'[^,]+',1,rownum) str
  FROM dual
    CONNECT BY rownum <= (LENGTH(你要转的字符串) - LENGTH(REGEXP_REPLACE(你要转的字符串, ',','')) + 1)
  1. 将行转列语句提取成一个Function
//header
TYPE r_str IS RECORD(
  str VARCHAR2( 100 ) 
);
TYPE t_str IS TABLE OF r_str;

FUNCTION get_separate_str(
    p_str IN VARCHAR2 DEFAULT NULL
) RETURN t_str PIPELINED;

//body
FUNCTION get_separate_str(
    p_str IN VARCHAR2 DEFAULT NULL )
  RETURN t_str PIPELINED
AS
  rec_out r_str;
BEGIN
  FOR rec IN
  (SELECT regexp_substr(p_str,'[^,]+',1,rownum) str
  FROM dual
    CONNECT BY rownum <= (LENGTH(p_str) - LENGTH(REGEXP_REPLACE(p_str, ',','')) + 1)
  )
  LOOP
    rec_out.str := rec.str;
    PIPE ROW (rec_out);
  END LOOP;
  RETURN;
END get_separate_str;

相关文章

  • sql中列转行unpivot、行转列pivot详细讲解||Mys

    目录:一、sqlserver列转行、行转列详解二、Oracle列转行、行转列详解三、DB2列转行、行转列详解四、M...

  • Oracle 行转列

    行转列,以, 分隔 将行转列语句提取成一个Function

  • oracle行转列

    一、PIVOT实例 1. 建表 建立一个销售情况表,其中,year字段表示年份,quarter字段表示季度,amo...

  • 【oracle】行转列

  • Oracle 行转列实例

    表结构和数据 行转列样式 /*姓名 语文 数学 英语王五 89 56 89*/ 方法一 ...

  • ORACLE11 行转列

    例如需要将以下左图存储的数据 查询显示为 右图存储的数据: 以下是测试数据的准备SQL: 第一种实现方式:(利用M...

  • oracle聚合查询行转列

    表为消费流水表 关键字段mdid,viptype,je,jzrq 需求统计按各门店,各月份,所有会员以及三种不同会...

  • Oracle 行转列实例二

    上篇文章在行转列时给出了两种方法,现在给出另外的两种方法。https://www.jianshu.com/p/76...

  • oracle行转列专题(六)

    中国移动sql面试题:create table test(id number(10) primary key,ty...

  • SQL Server行转列

    SQL行转列 经典实例 创建表格 SQL行转列 经典实例 创建表格 行转列 结果 参考链接

网友评论

      本文标题:Oracle 行转列

      本文链接:https://www.haomeiwen.com/subject/jxprpftx.html