PL/SQL表---table()函数用法
/*PL/SQL表---table()函数用法:
利用table()函数,我们可以将PL/SQL返回的结果集代替table。Oracle内存表在查询和报表的时候用的比较多,它的速度相对物理表要快几十倍。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));select * from the(select f_test_array(10) from dual);/*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));select * from the(select f_test_pipe(20) from dual);/*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);Oracle 查询执行顺序Oracle case when 根据结果改变查询出来的值相关资讯 Oracle数据库 Oracle入门教程 oracle数据库教程
- Oracle数据库全球化 (03月01日)
- Oracle数据库日期过滤方法性能比较 (02/02/2015 13:20:26)
- Oracle数据库安装中端口被占用问题 (10/29/2014 07:42:24)
| - 在CentOS 6.6上搭建C++运行环境并 (10/10/2015 19:44:40)
- Oracle数据库无法使用localhost和 (11/14/2014 16:39:10)
- 使用SQLT来构建Oracle测试用例 (08/28/2014 06:17:41)
|
本文评论 查看全部评论 (0)