oracle 查询数据横向,Oracle 查询存储过程做横向报表的方法

因为要牵扯到小计,所以需要计算两次。

想法:

1、把查询到的结果,插入到临时表,

2、把统计结果插入到临时表。

3、查询临时表记录放置到游标中。

4、删除临时表记录。

包的定义声明:

复制代码 代码如下:

CREATE OR REPLACE PACKAGE CHEN_TEST_PACKGE IS

type cursor_type is ref cursor;

/************************************************************************************/

/*  功能说明:查询某种公告报表                                                      */

/*  参数说明:                                                                      */

/*         i_id_capital_dynamic_manage IN   VARCHAR2          某种公告ID            */

/*         o_cursor                  OUT  cursor_type       返回游标                */

/*                                                                                  */

/*  创建日期         姓名                                                           */

/*  2013-03-08       路人甲                                                         */

/************************************************************************************/

PROCEDURE p_list_bulletin_report(  i_id_capital_dynamic_manage       IN       VARCHAR2,

o_cursor                 OUT      cursor_type);

END CHEN_TEST_PACKGE;

包的实现:

复制代码 代码如下:

CREATE OR REPLACE PACKAGE BODY CHEN_TEST_PACKGE IS

/************************************************************************************/

/*  功能说明:查询某种公告报表                                                      */

/*  参数说明:                                                                      */

/*         i_id_capital_dynamic_manage IN   VARCHAR2          某种公告ID            */

/*         o_cursor                  OUT  bulletin_report_type       返回游标       */

/*                                                                                  */

/*  创建日期         姓名                                                           */

/*  2013-03-08       路人甲                                                         */

/************************************************************************************/

PROCEDURE p_list_bulletin_report(  i_id_capital_dynamic_manage       IN       VARCHAR2,

o_cursor                 OUT      bulletin_report_type)

AS

set_id_bulletin_report_temp VARCHAR2(50); -- 定义临时变量

BEGIN

begin

--给临时变量赋值

--select to_char(sysdate,'yyyymmddhh24missSSS') into set_id_bulletin_report_temp from dual;

select i_id_capital_dynamic_manage into set_id_bulletin_report_temp from dual;

--获取数据插入临时表

insert into scms_bulletin_report_temp

(

id_bulletin_report_temp,

biz_Name                      ,

t01                           ,

t07                           ,

t14                           ,

t21                           ,

t1M                           ,

t2M                           ,

t3M                           ,

t4M                           ,

t5M                           ,

t6M                           ,

t1Y                           ,

t2Y                           ,

tCount                        ,

sort_no

)

select c.*,

rownum as sort_no

from(

select

set_id_bulletin_report_temp as id_bulletin_report_temp,

scms_common_packge.get_biz_name(b.biz_id) as biz_Name,

max(case  when b.term_type='T01' then b.c else 0 end) as T01,

max(case  when b.term_type='T07' then b.c else 0 end) as T07,

max(case  when b.term_type='T14' then b.c else 0 end) as T14,

max(case  when b.term_type='T21' then b.c else 0 end) as T21,

max(case  when b.term_type='T1M' then b.c else 0 end) as T1M,

max(case  when b.term_type='T2M' then b.c else 0 end) as T2M,

max(case  when b.term_type='T3M' then b.c else 0 end) as T3M,

max(case  when b.term_type='T4M' then b.c else 0 end) as T4M,

max(case  when b.term_type='T5M' then b.c else 0 end) as T5M,

max(case  when b.term_type='T6M' then b.c else 0 end) as T6M,

max(case  when b.term_type='T1Y' then b.c else 0 end) as T1Y,

max(case  when b.term_type='T2Y' then b.c else 0 end) as T2Y,

sum(b.c) as BIZ_ID_COUNT

from

(

select a.term_type,a.biz_id, sum(a.capital_claim) c

from (select report.capital_claim,

report.biz_id,

detail.term_type

from scms_capital_claim_report   report,

scms_capital_assign_detail  detail,

scms_capital_dynamic_manage manager

where manager.id_capital_dynamic_manage = detail.id_capital_dynamic_manage

and report.id_capital_assign_detail = detail.id_capital_assign_detail

and detail.id_capital_dynamic_manage = i_id_capital_dynamic_manage

and manager.IS_SETTLEMENT = '1'

and manager.IS_CONFIRM = '1'

) a

group by a.term_type, a.biz_id

) b group by b.biz_id

) c;

-- 插入总记录数

insert into scms_bulletin_report_temp

(

id_bulletin_report_temp,

biz_Name                      ,

t01                           ,

t07                           ,

t14                           ,

t21                           ,

t1M                           ,

t2M                           ,

t3M                           ,

t4M                           ,

t5M                           ,

t6M                           ,

t1Y                           ,

t2Y                           ,

tCount                        ,

sort_no

)

select c.*,

(select max(sort_no)+1 from scms_bulletin_report_temp te where te.id_bulletin_report_temp = set_id_bulletin_report_temp ) as sort_no

from(

select

set_id_bulletin_report_temp as id_bulletin_report_temp,

'总计(天数)' as biz_Name,

max(case  when b.term_type='T01' then b.c else 0 end) as T01,

max(case  when b.term_type='T07' then b.c else 0 end) as T07,

max(case  when b.term_type='T14' then b.c else 0 end) as T14,

max(case  when b.term_type='T21' then b.c else 0 end) as T21,

max(case  when b.term_type='T1M' then b.c else 0 end) as T1M,

max(case  when b.term_type='T2M' then b.c else 0 end) as T2M,

max(case  when b.term_type='T3M' then b.c else 0 end) as T3M,

max(case  when b.term_type='T4M' then b.c else 0 end) as T4M,

max(case  when b.term_type='T5M' then b.c else 0 end) as T5M,

max(case  when b.term_type='T6M' then b.c else 0 end) as T6M,

max(case  when b.term_type='T1Y' then b.c else 0 end) as T1Y,

max(case  when b.term_type='T2Y' then b.c else 0 end) as T2Y,

sum(b.c) as BIZ_ID_COUNT

from

(

select a.term_type,'biz_id_count' as biz_id, sum(a.capital_claim) c

from (select report.capital_claim,

report.biz_id,

detail.term_type

from scms_capital_claim_report   report,

scms_capital_assign_detail  detail,

scms_capital_dynamic_manage manager

where manager.id_capital_dynamic_manage = detail.id_capital_dynamic_manage

and report.id_capital_assign_detail = detail.id_capital_assign_detail

and detail.id_capital_dynamic_manage = i_id_capital_dynamic_manage

and manager.IS_SETTLEMENT = '1'

and manager.IS_CONFIRM = '1'

) a

group by  a.term_type

) b group by b.biz_id

) c;

-- 查询刚刚插入的表记录

open o_cursor for

select

id_bulletin_report_temp as idBulletinReportTemp,

biz_Name                as bizName  ,

t01                     as t01  ,

t07                     as t07  ,

t14                     as t14  ,

t21                     as t21  ,

t1M                     as t1M  ,

t2M                     as t2M  ,

t3M                     as t3M  ,

t4M                     as t4M  ,

t5M                     as t5M   ,

t6M                     as t6M   ,

t1Y                     as t1Y   ,

t2Y                     as t2Y   ,

tCount                  as tCount,

sort_no                 as sortNo

from scms_bulletin_report_temp temp

where temp.id_bulletin_report_temp = set_id_bulletin_report_temp

order by sortNo asc;

-- 删除:根据ID删除刚刚插入的记录

delete from scms_bulletin_report_temp temp where temp.id_bulletin_report_temp = set_id_bulletin_report_temp;

commit;

end;

END p_list_bulletin_report;

END CHEN_TEST_PACKGE;

/

页面调用ibatis的xml配置查询结果:

复制代码 代码如下:

{call CHEN_TEST_PACKGE.p_list_bulletin_report(?,?)}

java调用:

复制代码 代码如下:

String id_capital_dynamic_manage = request.getParameter("id_capital_dynamic_manage");

Map paraMap = new HashMap();

paraMap.put("i_id_capital_dynamic_manage", id_capital_dynamic_manage);

// 调用存储过程,查询

List resultList = (List>) CURDUtil.queryList("queryBulletinReportList", paraMap);

页面显示jsp:

复制代码 代码如下:

http://www.dengb.com/oracle/340039.htmlwww.dengb.comtruehttp://www.dengb.com/oracle/340039.htmlTechArticle因为要牵扯到小计,所以需要计算两次。 想法: 1、把查询到的结果,插入到临时表, 2、把统计结果插入到临时表。 3、查询临时表记录放...

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值