Welcome 微信登录

首页 / 数据库 / MySQL / PL/SQL表(Oracle内存表)---table()函数用法

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)
表情: 姓名: 字数