decode 查询

查出deptno=20,30部门的人员数和该部门应发的总工资
select e.deptno,count('*'), sum(e.sal)from emp e
where deptno in (20,30)
group by e.deptno

结果如下:
deptno count('*') sum(e.sal)
30 6 9400
20 5 10875


select count(decode(deptno,20,'X',null)) d20_count, sum(decode(deptno,20,sal,null)) d20_sal,count(decode(deptno,30,'X',null)) d30_count,
sum(decode(deptno,30,sal,null)) d30_sal from emp

结果如下:
d20_count d20_sal d30_count d30_sal
5 10875 6 9400

decode 解释:
DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )
Value 代表某个表的任何类型的任意列或一个通过计算所得的任何结果。当每个value值被测试,如果value的值为if1,Decode 函数的结果是then1;如果value等于if2,Decode函数结果是then2;等等。事实上,可以给出多个if/then 配对。如果value结果不等于给出的任何配对时,Decode 结果就返回else 。
  需要注意的是,这里的if、then及else 都可以是函数或计算表达式。


count 解释:
The COUNT(column) function returns the number of rows without a NULL value in the specified column.
使用COUNT(column)函数可以将不为NULL值的指定列的记录数返回出来。

count(*)是把from的表中所有的记录找出来

group by 解释
分组
通用数据库具有基于表的特定列对数据进行分析的能力。
可按照在 GROUP BY 子句中定义的组对行进行分组。以其最简单的形式,组由称为分组列的列组成。
SELECT 子句中的列名必须为分组列或列函数。列函数对于 GROUP BY 子句定义的每个组各返回一个结果。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值