--自定义对象

CREATE OR REPLACE TYPE Fas_checksheetinfo_line_obj AS OBJECT
(
  CSID_ID           VARCHAR2(32),--报账单明细ID
  CSI_ID            VARCHAR2(32),--报账单ID
  CSID_GENERATEDATE DATE,        --费用发生日期
  CSID_TYPE         VARCHAR2(32),--费用类型
  CSID_SUMMARY      VARCHAR2(256),--费用摘要
  CSID_CURRENCY     VARCHAR2(32),--币种
  CSID_VALUE        NUMBER,      --费用发生金额
  CREATEDBY         VARCHAR2(32),--生成人
  CREATEDDATE       DATE,        --生成日期
  LASTUPDATEDBY     VARCHAR2(32),--最后更改人
  LASTUPDATEDDATE   DATE,        --最后更改日期
  FLAG              VARCHAR2(32),--删除标识
  CSID_SEQ          NUMBER       --序号
)


自定义 table object

CREATE OR REPLACE TYPE Fas_checksheetinfo_line_tab AS TABLE OF Fas_checksheetinfo_line_obj;


pck

PROCEDURE checksheet_import(P_CSI_ID                  IN VARCHAR2, --报账单ID
                              P_CSI_CODE                IN VARCHAR2, --报账单编号
                              P_RI_ID                   IN VARCHAR2, --凭证ID
                              P_CSI_VALUE               IN NUMBER, --报账单金额
                              P_CSI_ORG                 IN VARCHAR2, --报账单位
                              P_CREATEDBY               IN VARCHAR2, --生成人
                              P_CREATEDDATE             IN DATE,     --生成日期
                              P_LASTUPDATEDBY           IN VARCHAR2, --最后更改人
                              P_LASTUPDATEDDATE         IN DATE,     --最后更改日期
                              P_FLAG2                   IN VARCHAR2, --删除标识
                              P_CSI_TYPE                IN VARCHAR2, --报账单类型
                              P_CSI_DEST                IN VARCHAR2, --目的地
                              P_CSI_GENERATEDATE        IN DATE,     --费用发生年月
                              P_CSI_COSTCENTER          IN VARCHAR2, --成本中心
                              P_CSI_SUMMARY             IN VARCHAR2, --摘要
                              P_CSI_PDFDIR              IN VARCHAR2, --pdf地址
                              P_GI_PDFDIR               IN VARCHAR2, --影像列表pdf地址
                              p_checksheetinfo_line_tab IN Fas_checksheetinfo_line_tab, --行信息,嵌套表
                              ----------------输出结果---------------------------
                              p_flag OUT NUMBER,
                              p_msg  OUT VARCHAR2) is
 
    v_cheksheet      ei_checksheetinfo%ROWTYPE;
    v_cheksheet_line ei_checksheetinfo_detail%ROWTYPE;
    v_line_count     number;
  begin
    null;
    p_flag := 0;
    p_msg := 'success';
    --插入报账单头信息表
    insert into ei_checksheetinfo
      (CSI_ID,
       CSI_CODE,
       RI_ID,
       CSI_VALUE,
       CSI_ORG,
       CREATEDBY,
       CREATEDDATE,
       LASTUPDATEDBY,
       LASTUPDATEDDATE,
       FLAG,
       CSI_TYPE,
       CSI_DEST,
       CSI_GENERATEDATE,
       CSI_COSTCENTER,
       CSI_SUMMARY,
       CSI_PDFDIR,
       GI_PDFDIR)
    values
      (P_CSI_ID,
       P_CSI_CODE,
       P_RI_ID,
       P_CSI_VALUE,
       P_CSI_ORG,
       P_CREATEDBY,
       P_CREATEDDATE,
       P_LASTUPDATEDBY,
       P_LASTUPDATEDDATE,
       P_FLAG,
       P_CSI_TYPE,
       P_CSI_DEST,
       P_CSI_GENERATEDATE,
       P_CSI_COSTCENTER,
       P_CSI_SUMMARY,
       P_CSI_PDFDIR,
       P_GI_PDFDIR);
    --插入行信息数据
    v_line_count := p_checksheetinfo_line_tab.COUNT;
    FOR i IN 1 .. v_line_count LOOP
      --p_line_errmsg(i).line_number := v_invoice_line_info_arr(i).line_number;
      insert into EI_CHECKSHEETINFO_DETAIL
        (CSID_ID,
         CSI_ID,
         CSID_GENERATEDATE,
         CSID_TYPE,
         CSID_SUMMARY,
         CSID_CURRENCY,
         CSID_VALUE,
         CREATEDBY,
         CREATEDDATE,
         LASTUPDATEDBY,
         LASTUPDATEDDATE,
         FLAG,
         CSID_SEQ)
      values
        (p_checksheetinfo_line_tab(i).CSID_ID,
         p_checksheetinfo_line_tab(i).CSI_ID,
         p_checksheetinfo_line_tab(i).CSID_GENERATEDATE,
         p_checksheetinfo_line_tab(i).CSID_TYPE,
         p_checksheetinfo_line_tab(i).CSID_SUMMARY,
         p_checksheetinfo_line_tab(i).CSID_CURRENCY,
         p_checksheetinfo_line_tab(i).CSID_VALUE,
         p_checksheetinfo_line_tab(i).CREATEDBY,
         p_checksheetinfo_line_tab(i).CREATEDDATE,
         p_checksheetinfo_line_tab(i).LASTUPDATEDBY,
         p_checksheetinfo_line_tab(i).LASTUPDATEDDATE,
         p_checksheetinfo_line_tab(i).FLAG,
         p_checksheetinfo_line_tab(i).CSID_SEQ);
    END LOOP;
    commit;
  EXCEPTION
    WHEN OTHERS THEN
      p_flag := 101;
      p_msg  := SQLERRM;
  end checksheet_import;


测试脚本

declare
  checksheetinfo_line_tab Fas_checksheetinfo_line_tab;
  p_flag                  number;
  p_msg                   varchar2(200);
begin
  --插入主表

--插入行表
  checksheetinfo_line_tab := Fas_checksheetinfo_line_tab();
  checksheetinfo_line_tab.extend;
  checksheetinfo_line_tab(1) := Fas_checksheetinfo_line_obj(CSID_ID           => 11,
                                                            CSI_ID            => 1,
                                                            CSID_GENERATEDATE => sysdate,
                                                            CSID_TYPE         => 11,
                                                            CSID_SUMMARY      => 11,
                                                            CSID_CURRENCY     => 11,
                                                            CSID_VALUE        => 11,
                                                            CREATEDBY         => 11,
                                                            CREATEDDATE       => sysdate,
                                                            LASTUPDATEDBY     => 11,
                                                            LASTUPDATEDDATE   => sysdate,
                                                            FLAG              => 11,
                                                            CSID_SEQ          => 11);
   --调用过程                                                       
  fas_checksheet_pkg.checksheet_import(1,
                                       1,
                                       1,
                                       1,
                                       1,
                                       1,
                                       sysdate,
                                       1,
                                       sysdate,
                                       1,
                                       1,
                                       1,
                                       sysdate,
                                       1,
                                       1,
                                       1,
                                       1,
                                       checksheetinfo_line_tab,
                                       p_flag,
                                       p_msg);
   --打印调用结果
   dbms_output.put_line('p_flag:' || p_flag || ',p_msg:' || p_msg);
end;

oracle 嵌套表的更多相关文章

  1. Oracle嵌套表

    一.介绍  1.定义 嵌套表是表中之表.一个嵌套表是某些行的集合,它在主表中表示为其中的一列.对主表中的每一条记录,嵌套表可以包含多个行.在某种意义上,它是在一个表中存储一对多关系的一种方法.    ...

  2. (转)oracle嵌套表示例

    本文转载自:http://www.cnblogs.com/gisdream/archive/2012/04/13/2445291.html ----嵌套表:就是把一个表中的字段定义为一个表,这个字段表 ...

  3. oracle ibatis 存储过程 返回游标 嵌套表

    自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...

  4. oracle:变长数组varray,嵌套表,集合

    创建变长数组类型 ) );  这个变长数组最多可以容纳两个数据,数据的类型为 varchar2(50) 更改元素类型的大小或精度 可以更改变长数组类型和嵌套表类型 元素的大小. ALTER TYPE ...

  5. oracle 之 数组、嵌套表、SQL查询式 实现多表数据for循环插入指定表

    1.基础环境 创建基础表: CREATE TABLE TEST_TAB1( ID INT, NAME VARCHAR2(20) ); CREATE TABLE TEST_TAB2( ID INT, N ...

  6. PL/SQL 嵌套表变长数组和索引表[转]

    关于PL/SQL中这三种数组的介绍,不想写了.转一篇日志吧…… 链接:http://www.blogjava.net/decode360/archive/2008/08/08/280825.html ...

  7. Oracle的表连接方式

    Oracle的表连接方式: 1.Nl Join连接(嵌套连接) 2.Hash Join(哈希连接) 3.Merge Sort Join(排序合并连接) 各种连接的使用场景: 1. 排序合并连接是偏向于 ...

  8. Oracle多表的简单查询

    Oracle多表的简单查询 .多表查询 多表查询是指基于两个和两个以上的表或是视图的查询. 问题:显示雇员名,雇员工资及所在部门的名字[笛卡尔集]? select t.ename,t.sal,t1.d ...

  9. 嵌套表用法详解(PLSQL)

    嵌套表 嵌套表是一种类似于索引表的结构,也可以用于保存多个数据,而且也可以保存复合类型的数据 嵌套表指的是一个数据表定义事同时加入了其他内部表的定义,这一概念是在oracle 8中引入的,它们可以使用 ...

随机推荐

  1. 2016.7.8 计算机网络复习要点第四章之地址解析协议ARP

    1.地址解析协议ARP:知道一个机器的IP地址,需要找到其相应的硬件地址:ARP协议的用途是为了从网络层使用的IP地址解析出在链路层使用的硬件地址: 2.由于是IP协议使用了ARP协议,因此通常就把A ...

  2. node工具--express

    //使用supervisor  Connect是基于HTTP米快创建的:Express则是基于Connect上创建的: 绝大多数web服务器和浏览器之间的任务是通过url和method完成的,两者的组 ...

  3. iOS数组排序

    [_fields sortUsingComparator:^NSComparisonResult(UITextField *obj1, UITextField *obj2) { /* NSOrdere ...

  4. 斐波那契数[XDU1049]

    Problem 1049 - 斐波那契数 Time Limit: 1000MS   Memory Limit: 65536KB   Difficulty: Total Submit: 1673  Ac ...

  5. BZOJ4320 : ShangHai2006 Homework

    取$M=\sqrt{300000}$. 设$g[i]$表示程序员的$\bmod i$最小的值. 若$Y<M$,那么可以在$O(M)$时间内完成对所有$g[i]$的修改,$O(1)$时间内完成查询 ...

  6. Android下载文件到SD卡

    HttpURLConnection 上传方式: 尝试理解这两种流的区别: InputStreamReader 的读取方式: //创建一个URL对象 URL url = new URL(urlStrin ...

  7. CentOS6.4 配置HAProxy+Keepalived

    安装HAProxy请参考 http://www.cnblogs.com/kgdxpr/p/3272861.html 安装Keepalived 1.下载安装依赖包 yum install -y wget ...

  8. 最大权闭合图 && 【BZOJ】1497: [NOI2006]最大获利

    http://www.lydsy.com/JudgeOnline/problem.php?id=1497 最大权闭合图详细请看胡伯涛论文<最小割模型在信息学竞赛中的应用>,我在这里截图它的 ...

  9. hiho 毁灭者问题

    描述 在 Warcraft III 之冰封王座中,毁灭者是不死族打三本后期时的一个魔法飞行单位. 毁灭者的核心技能之一,叫做魔法吸收(Absorb Mana): 现在让我们来考虑下面的问题: 假设你拥 ...

  10. 常用正则表达式(?i)忽略字母的大小写!

    1.^/d+$ //匹配非负整数(正整数 + 0) 2.^[0-9]*[1-9][0-9]*$ //匹配正整数 3.^((-/d+)|(0+))$ //匹配非正整数(负整数 + 0) 4.^-[0-9 ...