| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1210 人关注过本帖
标题:求一句case when语句实现和我写的select答案一样的sql语句
取消只看楼主 加入收藏
lgp740401
Rank: 1
等 级:新手上路
帖 子:52
专家分:5
注 册:2008-5-18
结帖率:91.67%
收藏
已结贴  问题点数:14 回复次数:1 
求一句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
快速回复:求一句case when语句实现和我写的select答案一样的sql语句
数据加载中...
 
   



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

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