DECODE 实现表的转置

数据库中的表是由列和行构成的一个二维表。一般列在任何数据库中都是有限的数量,而行的变化较大,如果表很大,行的数量可能大上千万行。同一列的不同行可能有不同的值,而且不是预先定义的。
  例:住房公积金报表置换实例:
  1.各个单位在本地经办行进行开户,开户就是将单位的基本信息和职工信息的进行登记;
  2.每月各个单位的会计到经办行交缴本单位的所有职工的住房公积金,系统记录有每个职工的交缴明细并在每条记录上记录有经办行的代码;
  3.每月、季、半年及年终都要求将经办行 变为“列”给出个月的明细报表:
  经办行:城西区 城东区
  月份:
  2001.01 xxxx1.xx xxxxx2.xx
  2001.02 xxxx3.xx xxxxx4.xx
  。 。 。 。 。 。
  原来的数据顺序是:
  城西区2001.01 xxxxx1.xx
  城东区2001.01 xxxxx2.xx
  城西区2001.02 xxxxx3.xx
  城东区2001.02 xxxxx4.xx
  住房公积金系统记录职工的每月交缴名细的pay_lst表结构是:
  bank_code varchar2(6)NOT NULL, -- 经办行代码
  acc_no varchar2(15) not null, -- 单位代码(单位帐号)
  emp_acc_no varchar2(20) not null, -- 职工帐号
  tran_date date not null, -- 交缴日期
  tran_val Number(7,2) not null, -- 交缴额
  sys_date date default sysdate, --系统日期
  oper_id varchar2(10) --操作员代码


这样的表结构,一般按照将经办行作为行(row)进行统计是很容易的,
但是如果希望将经办行变为列(column)这样的格式来输出就有困难。
如果用DECODE函数来处理则变得很简单:
我们创建一个视图来对目前的pay_lst表进行查询。
将经办行代码变为一些具体的经办行名称即可:

CREATE OR REPLACE VIEW bank_date_lst AS
  Select to_char(tran_date,’yyyy.mm’),
  SUM( DECODE ( bank_code,’001’, tran_val,0 )) 城西区,
  SUM( DECODE ( bank_code,’002’, tran_val,0 )) 城南区,
  SUM( DECODE ( bank_code,’003’, tran_val,0 )) 城东区
  FROM pay_lst
  GROUP BY to_char(tran_date,’yyyy.mm’);

建立视图后,可直接对该视图进行查询就可按照列显示出结果。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值