手机
当前位置:查字典教程网 >编程开发 >数据库其他 >存储过程返回数组对象示例代码
存储过程返回数组对象示例代码
摘要:其实就相当于返回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;

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

[数据库] 通用分页存储过程第1/5页

关于若干数据库数据插入性能的对比分析

数据库删除完全重复和部分关键字段重复的记录

数据库的三级模式和两级映射介绍

dba_indexes视图的性能分析

SQL四舍五入、向下取整、向上取整函数介绍

数据库建立索引的一般依据小结

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

Access转SqlServer的注意事项

复制数据库表中两个字段数据的SQL语句

精品推荐
分类导航