oracle 嵌套表
--自定义对象
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 嵌套表的更多相关文章
- Oracle嵌套表
一.介绍 1.定义 嵌套表是表中之表.一个嵌套表是某些行的集合,它在主表中表示为其中的一列.对主表中的每一条记录,嵌套表可以包含多个行.在某种意义上,它是在一个表中存储一对多关系的一种方法. ...
- (转)oracle嵌套表示例
本文转载自:http://www.cnblogs.com/gisdream/archive/2012/04/13/2445291.html ----嵌套表:就是把一个表中的字段定义为一个表,这个字段表 ...
- oracle ibatis 存储过程 返回游标 嵌套表
自己解决问题了 问题总结: 1.index by表不能存储在数据库中的type中,故选择嵌套表. 2.ibatis不支持oracle的复合数据类型的返回.(个人理解) 3.替代方案:用返回oracle ...
- oracle:变长数组varray,嵌套表,集合
创建变长数组类型 ) ); 这个变长数组最多可以容纳两个数据,数据的类型为 varchar2(50) 更改元素类型的大小或精度 可以更改变长数组类型和嵌套表类型 元素的大小. ALTER TYPE ...
- oracle 之 数组、嵌套表、SQL查询式 实现多表数据for循环插入指定表
1.基础环境 创建基础表: CREATE TABLE TEST_TAB1( ID INT, NAME VARCHAR2(20) ); CREATE TABLE TEST_TAB2( ID INT, N ...
- PL/SQL 嵌套表变长数组和索引表[转]
关于PL/SQL中这三种数组的介绍,不想写了.转一篇日志吧…… 链接:http://www.blogjava.net/decode360/archive/2008/08/08/280825.html ...
- Oracle的表连接方式
Oracle的表连接方式: 1.Nl Join连接(嵌套连接) 2.Hash Join(哈希连接) 3.Merge Sort Join(排序合并连接) 各种连接的使用场景: 1. 排序合并连接是偏向于 ...
- Oracle多表的简单查询
Oracle多表的简单查询 .多表查询 多表查询是指基于两个和两个以上的表或是视图的查询. 问题:显示雇员名,雇员工资及所在部门的名字[笛卡尔集]? select t.ename,t.sal,t1.d ...
- 嵌套表用法详解(PLSQL)
嵌套表 嵌套表是一种类似于索引表的结构,也可以用于保存多个数据,而且也可以保存复合类型的数据 嵌套表指的是一个数据表定义事同时加入了其他内部表的定义,这一概念是在oracle 8中引入的,它们可以使用 ...
随机推荐
- 用戶登陸。防SQL注入,驗證碼不區分大小寫
if (string.Compare(TBCheckCode.Text, Session["CheckCodeI"].ToString(), true) == 0) ...
- 安装完最小化 RHEL/CentOS 7 后需要做的 30 件事情(三)码农网
12. 安装 Apache Tomcat Tomcat 是由 Apache 设计的用来运行 Java HTTP web 服务器的 servlet 容器.按照下面的方法安装 tomcat,但需要指出的是 ...
- 二分查找法 java
前几天去面试,让我写二分查找法,真是哔了狗! 提了离职申请,没事写写吧! 首先二分查找是在一堆有序的序列中找到指定的结果. public class Erfen { public static int ...
- HDU2196 Computer(树形DP)
和LightOJ1257一样,之前我用了树分治写了.其实原来这题是道经典的树形DP,感觉这个DP不简单.. dp[0][u]表示以u为根的子树中的结点与u的最远距离 dp[1][u]表示以u为根的子树 ...
- HDU1247 Hat’s Words(Trie树)
常规做法是枚举每个字符串每个位置,时间复杂度O(n*len*len),(建字典树O(n*len)). 然而我看这题第一眼想的是时间复杂度O(n*len)的算法..就是建正反两棵字典树,每个字符串跑分别 ...
- Unity Built-in Shader详解二
这次主要讨论Unity自带的Shader中Transparent Shader Family 这个家族的Shader一共7种,原理和类型与Normal中的上差不多,只不过这些Shader是用在半透明或 ...
- 新旧各版本的MySQL可以从这里下载
http://downloads.mysql.com/archives/
- 【BZOJ】1507: [NOI2003]Editor(Splay)
http://www.lydsy.com/JudgeOnline/problem.php?id=1507 当练splay模板了,发现wjmzbmr的splay写得异常简介,学习了.orzzzzzzzz ...
- HDU 4671 Partition(定理题)
题目链接 这题,明显考察搜索能力...在中文版的维基百科中找到了公式. #include <cstdio> #include <cstring> #include <st ...
- php 配置正确的时间
关于php时区时间错误问题 date 当前时间 时差 当地 本地date_default_timezone_set 之前有一个遗留问题,就是echo date("y-m-d h:i:s&qu ...