1.创建表并制作测试数据;

--创建测试表 ;
CREATE TABLE split_table (
NAME VARCHAR2(100),
ID VARCHAR2(100) );
--准备测试数据 ;
INSERT INTO split_table VALUES('aa','11,12,13,14,15');
INSERT INTO split_table VALUES('bb','aa,bb,cc,dd,');
INSERT INTO split_table VALUES('cc','1a,2c,3d,,4c,55,,');
COMMIT ; --原理 ;
SELECT * FROM TABLE(splitstr((SELECT ID FROM  split_table WHERE NAME='aa' ),',')) a ;

2.编写拆分函数 :

CREATE OR REPLACE PACKAGE PACK_SPLIT_LISTAGG IS

  TYPE RECORD_SPLIT_TABLE_TYPE IS RECORD(
V_NAME VARCHAR2(100),
V_ID VARCHAR2(100));
REC_ST RECORD_SPLIT_TABLE_TYPE;
TYPE SPLIT_TABLE_TYPE IS TABLE OF RECORD_SPLIT_TABLE_TYPE;
CURSOR CURSOR_ST IS
SELECT NAME, ID FROM SPLIT_TABLE;
FUNCTION FUN_TEST_SPLITLISTAGG RETURN SPLIT_TABLE_TYPE
PIPELINED; END PACK_SPLIT_LISTAGG;
/ CREATE OR REPLACE PACKAGE BODY PACK_SPLIT_LISTAGG IS FUNCTION FUN_TEST_SPLITLISTAGG RETURN SPLIT_TABLE_TYPE
PIPELINED AS
ROW_ST SPLIT_TABLE%ROWTYPE;
V_START NUMBER := 1;
V_INDEX NUMBER;
V_LENGTH NUMBER;
P_DELIMITER VARCHAR2(100) := ',';
BEGIN
OPEN CURSOR_ST;
LOOP
FETCH CURSOR_ST
INTO ROW_ST;
EXIT WHEN CURSOR_ST%NOTFOUND;
V_LENGTH := TO_NUMBER(LENGTH(ROW_ST.ID));
WHILE (V_START <= V_LENGTH) LOOP
V_INDEX := INSTR(ROW_ST.ID, P_DELIMITER, V_START);
IF V_INDEX = 0 THEN
REC_ST.V_NAME := ROW_ST.NAME;
REC_ST.V_ID := SUBSTR(ROW_ST.ID, V_START);
V_START := V_LENGTH + 1;
ELSE
REC_ST.V_NAME := ROW_ST.NAME;
REC_ST.V_ID := SUBSTR(ROW_ST.ID, V_START, V_INDEX - V_START);
V_START := V_INDEX + 1;
END IF;
PIPE ROW(REC_ST);
END LOOP;
V_START := 1;
END LOOP;
CLOSE CURSOR_ST;
RETURN;
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE(SQLCODE || SQLERRM);
END FUN_TEST_SPLITLISTAGG;
END PACK_SPLIT_LISTAGG;
/

3.测试代码及结果:

--测试代码 ;
SELECT * FROM TABLE(pack_split_listagg.FUN_TEST_SPLITLISTAGG);

4.谢谢 !

/* 总结:  pipelined  pipe row ();

1. 一般用于返回一个集合;record ,index_table();  nested_table(); array_table();

2.返回时一次性返回;  3.如果游标的 返回值是cur%rowtype 作为参数传递时应 应使用*(select * from )

4.因为RECODE()类型和 cursor%row类型一致 所以同3 ;  5.使用游标(weak 弱类型)没有返回值类型那么默认返回的是cur%rowtype 类型;

*/

SELECT *   FROM TABLE(FUNC_PDT_TAB(CURSOR(SELECT S.PRODUCTID  , S.PRODUCTCODE, S.PRODUCTNAME   FROM SYS_PRODUCT S   ORDER BY S.PRODUCTID)));

select * FROM sys_product ; select * FROM emp ;

select * FROM TABLE(TEST_EMP_CURSOR(CURSOR(SELECT e.empno,e.ename,e.job FROM emp e))) ;

select * FROM TABLE(TEST_EMP_CURSOR_1(CURSOR(SELECT * FROM emp e))) ; --正确的写法;

select * FROM TABLE(TEST_EMP_CURSOR_1(CURSOR(SELECT e.empno,e.ename,e.job FROM emp e))) ;--抛错!

select * FROM TABLE(TEST_EMP_CURSOR_2(CURSOR(SELECT e.empno,e.ename,e.job FROM emp e))) ;

-------------------------------------------------------------------------

PIPELINED 基础用法 :

CREATE OR REPLACE PACKAGE REFCUR_PKG IS
TYPE REFCUR_T IS REF CURSOR RETURN EMP_BAK%ROWTYPE;
TYPE OUTREC_TYP IS RECORD(
VAR_EMPNO NUMBER(6),
VAR_EMPNAME VARCHAR2(30),
VAR_MGR VARCHAR2(30));
TYPE OUTRECSET IS TABLE OF OUTREC_TYP;
FUNCTION F_TRANS(P REFCUR_T) RETURN OUTRECSET
PIPELINED;
END REFCUR_PKG;
/ CREATE OR REPLACE PACKAGE BODY REFCUR_PKG IS
FUNCTION F_TRANS(P REFCUR_T) RETURN OUTRECSET
PIPELINED IS
OUT_REC OUTREC_TYP;
IN_REC P%ROWTYPE;
BEGIN
LOOP
FETCH P
INTO IN_REC;
EXIT WHEN P%NOTFOUND;
-- first row
OUT_REC.VAR_EMPNO := IN_REC.EMPNO;
OUT_REC.VAR_ENAME := IN_REC.ENAME;
OUT_REC.VAR_MGR := IN_REC.MGR;
PIPE ROW(OUT_REC);
-- second row
OUT_REC.VAR_NUM := IN_REC.DEPTNO;
OUT_REC.VAR_CHAR1 := IN_REC.DEPTNO;
OUT_REC.VAR_CHAR2 := IN_REC.JOB;
PIPE ROW(OUT_REC);
END LOOP;
CLOSE P;
RETURN;
END;
END REFCUR_PKG;

还原 listagg/wm_concat 后的数据 pack_split_listatt ;的更多相关文章

  1. SSL/TLS/WTLS原理(密钥协商的形象化比喻:验证服务器的身份,用服务器的公钥协商加密格式,然后再加密具体的消息,TCP传递SSL处理后的数据)good

    一 前言 首先要澄清一下名字的混淆: 1 SSL(Secure Socket Layer)是netscape公司设计的主要用于web的安全传输协议.这种协议在WEB上获得了广泛的应用. 2 IETF( ...

  2. 转:SqlServer2008误操作数据(delete或者update)后恢复数据

    Sqlserver2008误操作数据(delete或者update)后恢复数据(转) 实际工作中,有时会直接在数据库中操作数据,比如对数据进行delete或者update操作,当进行这些操作的时候,如 ...

  3. PDA手持扫描资产标签,盘点完成后将数据上传到PC端,固定资产系统查看盘点结果

    固定资产管理系统介绍: 致力于研发条码技术.集成条码系统的专业性公司,针对客户的不同需求,提供一站式的企业条码系统解决方案:包括功能强大的软件系统.安全可靠的无线网络.坚固耐用的硬件系统.灵活易用的管 ...

  4. 如何用perl将表格中不同列的数据进行拼凑,然后将拼凑后的数据用“|”连接在一起

    最近写了一个perl脚本,实现的功能是将表格中其中两列的数据进行拼凑,然后将拼凑后的数据用“|”连接在一起. 表格内容如下: 员工号码 员工姓名 职位 入职日期 1001 张三 销售 1980/12/ ...

  5. SqlServer触发器判断对表操作类型(增、删、改)并将修改后的数据映射到新表

    该文章为原创,日后可能会根据实际开发经验和网友评论,进行相应地方修改,为获得最新博客动态,望在转发博客的时候注明出处. 触发器要实现的功能: (1)获取对表Table1数据操作操作类型(insert. ...

  6. input中空格后的数据不显示

    bug,input中空格后的数据不显示     昨天在修bug,有一个bug是用户修改的个人信息的地址栏,输入有空格的话,空格后面的内容存不上,而且没有报错,奇怪了,只好跟踪下. 页面上的输入框就是个 ...

  7. GDAL 遥感图像处理后的数据保存为图像文件的实现方法

    在遥感图像处理中,GDAL库不仅能读取和处理大部分的遥感图像数据,而且还能够实现图像处理后将数据保存为图像的功能. 本文就详细介绍如何将内存中的图像数据保存为.tif格式. 首先,遥感数据处理完,保存 ...

  8. opencv face-detection 代码分析 (1)人脸识别后的数据

    2014,3,16   老师的工作建议如下:   1. 与四民沟通下,把openCV这边的源代码和调用接口发给四民同时抄送给我. 2. 根据openCV的实时检测结果,实现对屏幕的调整(下周一前基本实 ...

  9. SQLSERVER中返回修改后的数据

    在公司看到同事写了个SQL2005的新特性的文章,觉得很实用,在这里和大家分享下. 这种技术主要是用到了inserted和deleted虚拟表,这两张表相信大家都很熟悉.以前我们主要是在触发器中使用. ...

随机推荐

  1. C语言进阶——基本数据类型01

    刚开始人们还没有数据类型这个概念,但是人们经常要使用到固定内存大小的内存,这个时候那时的程序员就要记录一段信息在内存中的起始位置和终止位置,很不方便,演变到后来就出现了数据类型这个概念 什莫是数据类型 ...

  2. scala (4) 可变数组和不可变数组

    在scala中数组分为不可变长数组(在immutable包下)和可变长数组(在mutable包下) 不可变长数组指的是长度不可变,但是数组中角标对应的元素的值是可变的 可变数组指的是长度和数组中角标对 ...

  3. TCGA数据批量下载

    由于经常需要涉及到TCGA数据的分析,我简单的整理了一下数据批量下载的文件后缀. cancer_name <- "SKCM" output_path <- paste0 ...

  4. 【C】对指针表达式的个人总结与思考

    本文内容参考<c 和 指针>. 声明:本博文只为那些能沉得住气,认真研究,探索真知的人参考,浮躁的人请离开,因为看不懂. 感觉以前学c的时候,学的指针真是白学了,今天看到这个内容,困惑后, ...

  5. gulp 输出到同一目录

    gulp.task('jsx', function () { var src='app/script/**/*.jsx'; // src='app/script/components/selloff/ ...

  6. 20155233 实验一 Java开发环境的熟悉(Linux + IDEA)

    20155233 实验一 Java开发环境的熟悉(Linux + IDEA) 实验内容 1.使用JDK编译.运行简单的Java程序: 2.使用IDEA编辑.编译.运行.调试Java程序. 实验步骤 ( ...

  7. 20155321 《Java程序设计》实验报告一:Java开发环境的熟悉(Windows+IDEA)

    实验要求 使用JDK编译.运行简单的Java程序: 使用IDEA 编辑.编译.运行.调试Java程序. 实验内容 命令行下Java程序开发 打开windows下的cmd → 输入cd Code命令进入 ...

  8. WPF ControllTemplate Triggers小记 - 简书

    原文:WPF ControllTemplate Triggers小记 - 简书 WPF中,样式模板中如果定义EventTrigger事件方式实现动画.那么需要注意两点: 1.对于绑定的属性的Event ...

  9. 【LG5022】[NOIP2018]旅行

    [LG5022][NOIP2018]旅行 题面 洛谷 题解 首先考虑一棵树的部分分怎么打 直接从根节点开始\(dfs\),依次选择编号最小的儿子即可 而此题是一个基环树 怎么办呢? 可以断掉环上的一条 ...

  10. 车架号识别,VIN码识别 助力汽车后市场

    又有一家汽配圈新贵引入了小译家的 车架号识别(VIN码识别)技术 那就是明觉科技 是一个服务于汽车后市场 集数据服务.行业数据挖掘 及“互联网+”为一体的汽配信息协作平台 旗下拥有一款全车零配件信息智 ...