利用函数返回oracle对象表的三种方法

 更新时间:2016年07月18日 09:32:43   作者:ryan1985  
这篇文章主要为大家详细介绍了利用函数返回oracle对象表的三种方法,感兴趣的小伙伴们可以参考一下

因为要返回表对象,无论后续用什么方法返回,都先要声明全局type;并且,字段变量类型要为object,不能为record:

create or replace type t_test as object(
 EMPNO  NUMBER(4),
 ENAME  VARCHAR2(10),
 JOB   VARCHAR2(9),
 SAL   NUMBER(7,2)
);

create or replace type t_test_table as table of t_test;

至于返回表对象的方法,目前发现三种:
 1、用数组

create or replace function f_test_array(v_deptno in number default null)
return t_test_table
is 
v_test t_test_table := t_test_table();
cursor cur is select empno, ename, job, sal from emp where deptno = v_deptno;
begin
for c in cur loop
v_test.extend();
v_test(v_test.count) := t_test(c.empno, c.ename, c.job, c.sal);
end loop;
return v_test;
end;

2、用pipe

create or replace function f_test_pipe(v_deptno in number default null)
return t_test_table PIPELINED 
is
v_test t_test_table := t_test_table();
cursor cur is select empno, ename, job, sal from emp where deptno = v_deptno;
begin 
for c in cur loop
pipe row(t_test(c.empno, c.ename, c.job, c.sal)); 
end loop; 
return; 
end;

这两种都需要用游标遍历,得到表对象,性能上估计第2种较高。 

3、用collect(不需要游标,代码相对简单)

create or replace function f_test_collect(v_deptno in number default null)
return t_test_table
is 
v_test t_test_table := t_test_table();
begin
select t_test(empno, ename, job, sal) bulk collect into v_test from emp where deptno = v_deptno;
return v_test;
end;

需要注意的是,select into之前要先把输出结果对象化:
t_test(empno, ename, job, sal)
否则会报错: 
ORA-00947: 没有足够的值(object多字段)
ORA-00932: 数据类型不一致(object单一字段)
而如果直接在plsql块中declare类型的话,是不需要先对象化输出结果的。
三种函数定义方式可以测试输出一样的结果:

select * from table(f_test_pipe(30));
select * from table(f_test_array(30));
select * from table(f_test_collect(30));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Oracle数据库中TRUNC()函数示例详解

    Oracle数据库中TRUNC()函数示例详解

    在Oracle数据库中TRUNC函数主要用于截断日期、时间或数值,通过指定不同的格式参数,可以截取日期或时间的特定部分,如年份、月份、小时等,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-10-10
  • 在Linux下安装Oracle

    在Linux下安装Oracle

    在Linux下安装Oracle...
    2007-03-03
  • Oracle to_char函数的使用方法

    Oracle to_char函数的使用方法

    在Oracle数据库中,to_char函数是我们最常用的函数之一,下文对to_char函数的应用作了详细的介绍,如果您感兴趣的话,不妨一看
    2014-08-08
  • 解决Oracle字符串中包含数字、特殊符号的排序问题

    解决Oracle字符串中包含数字、特殊符号的排序问题

    最近做项目遇到这样的需求,要求实现某小区需要按照小区、楼栋、单元号、房间号进行排序。看似很简单的一个需求,一条sql语句搞定,其实套路很深,下面小编给大家分享下Oracle字符串中包含数字、特殊符号的排序问题
    2017-11-11
  • oracle异常(预定义异常,自定义异常)应用介绍

    oracle异常(预定义异常,自定义异常)应用介绍

    在开发过程中,经常会遇到一些测试,这时候就会想了解测试的过程,然后再根据过程分析代码错在哪里,这种情况下,就需要用到自定义异常,需要了解的朋友可以参考本文
    2012-11-11
  • SQL优化之针对count、表的连接顺序、条件顺序、in及exist的优化

    SQL优化之针对count、表的连接顺序、条件顺序、in及exist的优化

    这篇文章主要介绍了SQL优化之针对count、表的连接顺序、条件顺序、in及exist的优化,有助于读者深入理解Oracle的运行效率及优化策略,需要的朋友可以参考下
    2014-07-07
  • plsql和tsql常用函数比对

    plsql和tsql常用函数比对

    plsql与tsql的语法不同,大家可以参考下。
    2009-09-09
  • Oracle SQL注入的实例总结

    Oracle SQL注入的实例总结

    在网络中,数据库驱动的Web应用随处可见,由此而存在的SQL注入是影响企业运营且最具破坏性的漏洞之一,下面这篇文章主要给大家介绍了关于Oracle SQL注入的相关资料,需要的朋友可以参考下
    2021-11-11
  • Oracle常用命令大全集

    Oracle常用命令大全集

    Oracle常用命令大全集...
    2007-03-03
  • 使用JDBC连接ORACLE的三种URL格式

    使用JDBC连接ORACLE的三种URL格式

    这篇文章主要介绍了JDBC连接使用JDBC连接ORACLE的三种URL格式,每种格式通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-10-10

最新评论