数据库->SQL Server2005->第4季SQL从入门到提高->11练习和12练习1

本文详细介绍了使用SQL进行数据查询的技巧,包括如何利用CASE语句处理正负数,以及如何通过聚合函数进行数据汇总。文章通过两个具体的案例,演示了如何在不同场景下运用SQL查询来解决问题。

//--------------------------------练习1

将这这张表

单号 金额

RK1  10

RK2  20

RK3  -30

RK4  -10

 

查询后输出如下结果:

单号  收入  支出

RK1  10  0

RK2  20  0

RK3  0  30

RK4  0  10

 

解题思路:

用流控函数,解题代码,

 

select FNumber as 单号,
(
case
when FAmount>0 then FAmount
else 0
end
) as 收入,
(
case
when FAmount<0 then abs(FAmount)
else 0
end
)as 支出
from T_Test1

 

//----------------------------------------- 练习2

表数据如下:

 

查询结果如下:

 

 

实现代码:

首先,看到这样的结果,

select Name,
(
case
when Score=N'胜' then 1
else 0
end
)as 胜,
(
case
when Score=N'负' then 1
else 0
end
)as 负

from T_Scores

 

再是最终结果,

select Name,
sum((
case
when Score=N'胜' then 1
else 0
end
))as 胜,
sum((
case
when Score=N'负' then 1
else 0
end
))as 负
from T_Scores group by Name
 

 

转载于:https://www.cnblogs.com/samwu/archive/2011/06/14/2080813.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值