首页 > 数据库 > Oracle > 正文

从Oracle 表格行列转置说起第1/2页

2020-07-26 14:33:03
字体:
来源:转载
供稿:网友

NOMONEYDAY
1231
1432
1-453
2421
2-102
2503
31008

为了符合阅读习惯,最终报表希望是如下格式:

NOMONTUETHR
12343-45
242-1050
3   

------------------------

咱们一步步来实现:

1.运用DECODE转换行为列

SQL:

SELECT NO,
    DECODE(DAY,1,MONEY,'') DAY1,
    DECODE(DAY,2,MONEY,'') DAY2,
    DECODE(DAY,3,MONEY,'') DAY3
FROM TEMP

结果:

NODAY1DAY2DAY3
123
143
1-45
242
2-10
250
3   

2.按NO字段分组,并更改列名

SQL:

SELECT NO, MAX(DAY1) MON, MAX(DAY2) TUE, MAX(DAY3) THR
 FROM (SELECT NO,
        DECODE(DAY, 1, MONEY,'') DAY1,
        DECODE(DAY, 2, MONEY,'') DAY2,
        DECODE(DAY, 3, MONEY,'') DAY3
     FROM TEMP)
 GROUP BY NO;

结果:

NOMONTUETHR
12343-45
242-1050
3   

------------------------

重难点归纳:

1.DECODE缺省值设置

DECODE语法如下:decode(条件,值1,翻译值1,值2,翻译值2,...值n,翻译值n,缺省值)

如果缺省值由''(两个单引号)改为0,即SQL:

SELECT NO, MAX(DAY1) MON, MAX(DAY2) TUE, MAX(DAY3) THR
 FROM (SELECT NO,
        DECODE(DAY, 1, MONEY,0) DAY1,
        DECODE(DAY, 2, MONEY,0) DAY2,
        DECODE(DAY, 3, MONEY,0) DAY3
     FROM TEMP)
 GROUP BY NO;

结果如下(所有值为负与空值都被赋为0):

NOMONTUETHR
123430
242050
3000

2.列缺省值设置(DAY值为8的显示为'undefined')

SQL:

SELECT NO,MONEY,
    DECODE(DAY,1,'MON',2,'TUE',3,'THR','undefined') DAY
FROM TEMP

结果:

NOMONEYDAY
123MON
143TUE
1-45THR
242MON
2-10TUE
250THR
3100undefined

3.行列转化在表单内数据量较大的情况下消耗较大

原因:

1.扫描目标数据时间开销大。

2.GROUP BY时,数据冗余带来的多行合并。

优点:

表结构稳定:DAY增加新值只需增加记录,无需新增新列!

下一页 decode()函使用技巧
12下一页阅读全文
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表