标题:求一句case when语句实现和我写的select答案一样的sql语句
只看楼主
lgp740401
Rank: 1
等 级:新手上路
帖 子:52
专家分:5
注 册:2008-5-18
结帖率:91.67%
已结贴  问题点数:14 回复次数:3 
求一句case when语句实现和我写的select答案一样的sql语句
意思:我实发金额中包括了班内工资+班外工资,当chk班内=0(不在班内),实际班内工资=实发金额-数量*单价(不在班内的工资)

我有一个表(Tb_工资姓名_b)如下:
姓名    数量     单价    chk班内     班内金额     实发金额   jlsjh
xxa     52        1        0            50          102      _49P18Y2VP_49P18Y2VQ
xxb     48        1        1            50           98      _49P18Y2VP_49P18Y2VQ                                         
xxc     0         0        1            50           50      _49P18Y2VP_49P18Y2VQ
用这个sql语句可以得到正确答案---198:
SELECT SUM(实发金额) -(SELECT SUM(数量 * 单价) FROM  Tb_工资姓名_b WHERE jlsjh_tb_工资姓名 = '_49P18Y2VP_49P18Y2VQ' AND chk班内 = 0) AS 实发金额
FROM Tb_工资姓名_b WHERE jlsjh_tb_工资姓名 = '_49P18Y2VP_49P18Y2VQ'
但我想用一种更简便的case when如下语句却得不到正确答案250:
SELECT  SUM(实发金额 -CASE WHEN chk班内 = 0 THEN 0 ELSE 数量 * 单价 END) AS 实发金额 FROM Tb_工资姓名_b WHERE jlsjh_tb_工资姓名 = '_49P18Y2VP_49P18Y2VQ'
请教一下各位,怎么写?
再简化:
SELECT  SUM(CASE WHEN chk班内 = 0 THEN 0 ELSE 数量 * 单价 END) AS 实发金额 FROM Tb_工资姓名_b WHERE jlsjh_tb_工资姓名 = '_49P18Y2VP_49P18Y2VQ'
不起作用?为何?



[ 本帖最后由 lgp740401 于 2015-4-16 12:48 编辑 ]
搜索更多相关主题的帖子: sql语句 姓名 
2015-04-15 17:07
lgp740401
Rank: 1
等 级:新手上路
帖 子:52
专家分:5
注 册:2008-5-18
得分:0 
难道用case when用不上吗?


[ 本帖最后由 lgp740401 于 2015-4-16 12:57 编辑 ]
2015-04-16 12:41
mxbing1984
Rank: 7Rank: 7Rank: 7
来 自:贵州道真
等 级:贵宾
威 望:37
帖 子:73
专家分:342
注 册:2014-8-8
得分:14 
SELECT  SUM(班内金额+CASE WHEN chk班内 = 0 THEN 0 ELSE 数量 * 单价 END) AS 实发金额 FROM Tb_工资姓名_b WHERE jlsjh = '_49P18Y2VP_49P18Y2VQ'
这样就对了

天再高,踮起脚尖就能更接近阳光
2015-04-17 16:41
mxbing1984
Rank: 7Rank: 7Rank: 7
来 自:贵州道真
等 级:贵宾
威 望:37
帖 子:73
专家分:342
注 册:2014-8-8
得分:0 
SELECT  SUM(实发金额 -CASE WHEN chk班内 = 1 THEN 0 ELSE 数量 * 单价 END) AS 实发金额 FROM Tb_工资姓名_b WHERE jlsjh = '_49P18Y2VP_49P18Y2VQ'
这样也是一样的

天再高,踮起脚尖就能更接近阳光
2015-04-17 16:43



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-444044-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.191913 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved