手机
当前位置:查字典教程网 >编程开发 >数据库其他 >存储过程返回数组对象示例代码
存储过程返回数组对象示例代码
摘要:其实就相当于返回List里面放的对象数据,定义如下1.创建存储过程对象复制代码代码如下:CREATEORREPLACETYPE"T_ACCO...

其实就相当于返回List里面放的对象数据,定义如下

1.创建存储过程对象

复制代码 代码如下:

CREATE OR REPLACE TYPE "T_ACCOUNT_MONTH"

as object(

ACCOUNT_ID NUMBER,

INIT_AMOUNT NUMBER,

DEBIT_AMOUNT NUMBER,

CREDIT_AMOUNT NUMBER

)

2.创建存数过程数组

复制代码 代码如下:

CREATE OR REPLACE TYPE "T_ACCOUNT_MONTH_TABLE"

as table of t_account_month

3.创建存储过程

复制代码 代码如下:

create or replace function account_month(tDate IN DATE)

return t_account_month_table pipelined

as

v_account_month t_account_month;

v_date DATE;

begin

v_date:=tDate;

IF v_date IS NULL THEN

v_date:=sysdate;

END IF;

for myrow in (

select d.ACCOUNT_ID,

sum(decode(sign(d.create_time-trunc(v_date,'month')),-1,

d.debit_unvoucher + d.debit_unposted +d.debit_posted - d.CREDIT_UNVOUCHER -d.CREDIT_UNPOSTED- d.CREDIT_POSTED_D,

0)) INIT_AMOUNT,

sum(decode(sign(trunc(d.create_time,'year')-trunc(sysdate,'year')),0,

d.debit_unposted+d.debit_posted,

0)) DEBIT_AMOUNT,

sum(decode(sign(trunc(d.create_time,'year')-trunc(sysdate,'year')),0,

d.credit_unposted+d.credit_posted,

0)) CREDIT_AMOUNT

from ACCOUNT_DAILY_VEIW d

group by d.ACCOUNT_ID

) loop

v_account_month := t_account_month(

myrow.ACCOUNT_ID,

myrow.INIT_AMOUNT,

myrow.DEBIT_AMOUNT,

myrow.CREDIT_AMOUNT

);

pipe row (v_account_month);

end loop;

return;

end;

【存储过程返回数组对象示例代码】相关文章:

ORACLE 系统函数大全SQLSERVER系统函数的异同

sql2005可实时监测数据库版本控制SQL的触发器

dba_indexes视图的性能分析

虚拟主机ACCESS转换成MSSQL完全攻略(图文教程)

特殊的存储过程-触发器概述

以前架征途时的合区的SQL语句代码备份

mysql、mssql及oracle分页查询方法详解

程序员应该知道的数据库设计的两个误区

Spring集成MyBatis完整实例(分享)

多种获取远程连接access数据库的方法

精品推荐
分类导航