plsql返回记录集的方法利用table

来源:互联网 发布:读书笔记 知乎 编辑:程序博客网 时间:2024/05/22 10:45

 

今天在开发的时候,要找出两个表中的不同记录。我一般是用exists的,但看到也可以这样

SELECT T5,T6,T7,T8 FROM TAB02 WHERE 
     T5||T6||T7 NOT IN 
     (SELECT T1||T2||T3 FROM TAB01)

把几个字段合并成一个字段,虽然很SB,但可以解决问题。

下面是重点,集合对象,以前我都是用游标来出来记录集,但有了集合对象后就可以直接加载记录集了,下面是一个使用集合对象record,table的例子

DECLARE 
      TYPE TEST_EMP IS RECORD
      (
       C1 AA.PI%TYPE,
       C2 AA.PO%TYPE
      );
      
      type t_type is table of TEST_EMP;    ---type t_type is table of aa%rowtype;
      v_type t_type;

BEGIN
     SELECT PI,PO BULK COLLECT INTO v_type
     FROM AA
     WHERE AA.PI <= 3;
     for v_index in 1 .. v_type.count() loop
         dbms_output.put_line(v_type(v_index).C1 || ' ' || v_type(v_index).C2);       
     end loop;
END;

下面我要解决怎样用过程返回一个集合。


PL/SQL表---table()函数用法:
利用table()函数,我们可以将PL/SQL返回的结果集代替table。

simple example:

1、table()结合数组:

create or replace type t_test as object(
id integer,
rq date,
mc varchar2(60)
);

create or replace type t_test_table as table of t_test;

create or replace function f_test_array(n in number default null) return t_test_table
as 
v_test t_test_table := t_test_table();
begin
for i in 1 .. nvl(n,100) loop
v_test.extend();
v_test(v_test.count) := t_test(i,sysdate,'mc'||i);
end loop;
return v_test;
end f_test_array;


select * from table(f_test_array(10));

/*

2、table()结合PIPELINED函数:

*/

create or replace function f_test_pipe(n in number default null) return t_test_table PIPELINED 
as 
v_test t_test_table := t_test_table();
begin 
for i in 1 .. nvl(n,100) loop
pipe row(t_test(i,sysdate,'mc'||i)); 
end loop; 
return; 
end f_test_pipe; 
/

select * from table(f_test_pipe(20));

/*

3、table()结合系统包:

*/

create table test (id varchar2(20));
insert into test values('1');
commit;
explain plan for select * from test;
select * from table(dbms_xplan.display);

 

原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 ucos qt包含文件 科大讯飞java 1,定义一个接口Assaultable(可攻击的),该接口有一个抽象方法attack()。2,定义一 FlyAudioVoice 2023 编写一个应用程序绘制一个如下的操作菜单并实现功能(定义一个类学生表示学生,有成员变量姓名name和年 Minecraft 1204:剔除相关数 平坦衰落信道2FSK差错性能分析 平坦衰落信道 编写一个应用程序绘制一个如下的操作菜单并实现功能(定义一个类学生表示学生,有成员变量姓名name和年 手机是现在人们必不可少、最重要的通讯工具,拥有一款简单、实用、易用的手机通讯录,将会使你的手机更加好 手机是现在人们必不可少、最重要的通讯工具,拥有一款简单、实用、易用的手机通讯录,将会使你的手机更加好 编写一个应用程序绘制一个如下的操作菜单并实现功能(定义一个类学生表示学生,有成员变量姓名name和年 61858 61850 全国市级城市拼音 pycr rpyc pry 安德地产公司 安德地产年报 pycharm安装 高文 李皓 王煊 赵瀚 夜的命名术 我的治愈系游戏 全职艺术家 星门 长夜余火 不科学御兽 十方武圣 黎明之剑 深空彼岸 稳住别浪 这个人仙太过正经 从红月开始 林渊