oracle纵向统计,oracle横向纵向求和代码实例

有一张工资表SALARY如下, (NO 员工编号 ,MONEY 工资)

NO NAME ITEM MONEY

001 张三 工资 80

001 张三 补贴 86

001 张三 奖金 75

002 李四 工资 78

002 李四 补贴 85

002 李四 奖金 78

求每个人的总工资以及所有人的总工资,结果如下表:

结果如下:

姓名 工资 补贴 奖金 总工资

李四 780 850 780 2410

张三 800 860 750 2410

总计 1580 1710 1530 4820

SQL语句:

SELECT DECODE(GROUPING(NAME), 1, '总计', NAME) 姓名,

SUM(DECODE(ITEM, '工资', MONEY, 0)) 工资,

SUM(DECODE(ITEM, '补贴', MONEY, 0)) 补贴,

SUM(DECODE(ITEM, '奖金', MONEY, 0)) 奖金,

SUM(MONEY) 总工资

FROM SALARY

GROUP BY ROLLUP(NAME);

其中:GROUPING函数接受一列,列值为空返回1,非空返回0,只能在使用ROLLUP或CUBE的查询中使用;

DECODE(ITEM, '工资', MONEY, 0) 是指ITME的值与‘工资'比较,如果相等返回MONEY,不等返回0

下面再看一个实例

有一张表test 如下, (NO 学生编号 ,cj 成绩)

NO name KM CJ

001 张三 语文 80

001 张三 数学 86

001 张三 英语 75

002 李四 语文 78

002 李四 数学 85

002 李四 英语 78

写了以下语句来算每项个科目的总分,

select decode(grouping(name),1,'总分',name) 姓名,

sum(decode(km, '数学',cj,0)) 数学,

sum(decode(km, '英语',cj,0)) 英语,

sum(decode(km, '语文',cj,0)) 语文,

sum(cj) 总成绩

from test group by rollup(name)

结果如下:

姓名 数学 英语 语文 总成绩

李四 85 78 78 241

张三 86 75 80 241

总分 171 153 158 482

总结

以上就是本文关于oracle横向纵向求和代码实例的全部内容,希望对大家有所帮助。感兴趣的朋友可以参阅:ORACLE SQL语句优化技术要点解析 、oracle数据库导入TXT文件方法介绍 、ORACLE多条件统计查询的简单方法 等。有什么问题可以随时留言,欢迎大家交流讨论。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值