zoukankan      html  css  js  c++  java
  • Oracle Table Function

    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
    ));


  • 相关阅读:
    node.js结合wechaty实现微信机器人[基础篇]
    .env文件为NodeJS全局环境变量
    基于jquery实现一个提示插件
    Puppeteer实现一个超简单的自动化机器人
    Vue高仿阿里动态banner,制作组件
    css不常用属性
    Vue表单校验失败滚动到错误位置
    C# Func委托
    深入解析C# 4th 笔记(第一章)
    C# 笔记 XML基础
  • 原文地址:https://www.cnblogs.com/lytwajue/p/7006946.html
Copyright © 2011-2022 走看看