Oracle Table Function在Oracle9i时引入。完美的兼容了view和存储过程的长处:

应用举例:

1.Table()函数:

set feedback off

create or replace type type_int_date_varchar2  as object (i integer, d date, v varchar2(99))
/ create or replace type table_int_date_varchar2 as table of
type_int_date_varchar2
/ create or replace function f_int_date_varchar2 return table_int_date_varchar2 as
a_type_int_date_varchar2 table_int_date_varchar2 := table_int_date_varchar2();
begin a_type_int_date_varchar2.extend;
a_type_int_date_varchar2(a_type_int_date_varchar2.count) :=
type_int_date_varchar2(1,to_date('08.01.1947','dd.mm.yyyy'), 'David Bowie'); a_type_int_date_varchar2.extend;
a_type_int_date_varchar2(a_type_int_date_varchar2.count) :=
type_int_date_varchar2(2,to_date('27.01.1756','dd.mm.yyyy'), 'Mozart'); return a_type_int_date_varchar2;
end;
/ select * from table (cast (f_int_date_varchar2() as table_int_date_varchar2)); drop function f_int_date_varchar2;
drop type table_int_date_varchar2;
drop type type_int_date_varchar2;

2.A Function that returns a table of dates in a Range

create or replace type date_obj as object (dt date)
/ create or replace type date_table as table of date_obj
/ create or replace function date_range(from_dt in date, to_dt in date)
return date_table as
a_date_table date_table := date_table();
cur_dt date:=from_dt;
begin
while cur_dt <= to_dt loop
a_date_table.extend;
a_date_table(a_date_table.count) := date_obj(cur_dt);
cur_dt := cur_dt + 1;
end loop;
return a_date_table;
end date_range;
/
select * from  table (
cast ( date_range(
to_date('01.01.2002','dd.mm.yyyy'),
to_date('31.01.2002','dd.mm.yyyy')
)
as date_table
));

最新文章

  1. mssql查询列名中包含特定字段的列
  2. 使用DiskFileItemFactory 实现文件上传 ,设定缓冲区大小和存放临时文件目录。
  3. jquery jQuery-File-Upload 例子
  4. Bestcoder Round 47 &amp;&amp; 48
  5. Java 零基础之作业小练习
  6. Android 沉浸式状态栏
  7. 20150820 PROCEDURE 模板
  8. 【MVC】ASP.NET MVC 请求生命周期
  9. tomcat 7 下添加 shared/lib 文件夹
  10. bzoj2597: [Wc2007]剪刀石头布
  11. 服务器编程入门(11)TCP并发回射服务器实现 - 单线程select实现
  12. http中的get和post(二)
  13. socket.io中 connect与connection的区别
  14. Linux(CentOs 7)系统重装笔记(一)
  15. 牛客练习赛43 Tachibana Kanade Loves Review C(最小生成树Kruskal)
  16. python全栈开发 * 19 面向对象 知识点汇总 * 180701
  17. 阿里云MaxCompute被Forrester评为全球云端数据仓库领导者
  18. 【mysql】排序方法
  19. jQuery UI 给button添加ID
  20. Kafka问题排查(消费者自动关闭)

热门文章

  1. JDBC 具体解释(1)
  2. getColor()方法过时的替代方法
  3. python 并发编程入门
  4. Ant批量处理jmeter脚本
  5. C#趣味程序---三色球问题
  6. 使用fiddler模拟http get
  7. 【SDOI 2016】 排列计数
  8. ThinkPHP5+Redis单例型购物车
  9. kubernetes系列:(二)、kubernetes部署mysql(单节点)
  10. Oracle学习系类篇(一)