您现在的位置:主页 > 技术中心 > 数据库技术 > Sqlserver

数据库->SQL Server2005->第4季SQL从入门到提高-&gt

来源:网络 责任编辑:admin 发表时间:2013-07-01 07:14 点击:

//--------------------------------练习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

    相关新闻>>

      发表评论
      请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
      评价:
      表情:
      用户名: 验证码:点击我更换图片

      推荐热点

      • sql常见面试题
      • SQL SERVER 2005性能之跟踪
      • SQL编程(一)
      • LINUX上RMAN自动备份脚本
      • sql server面试题
      • 浅谈SQL Server中的事务日志(三)----在简单恢复模式
      • SQL小技巧系列 --- 行转列合并
      • 如何将多个SQL查询统计结果一次显示出来
      • sql server 列转行
      ?? - ?? - ÝřŝžľŘÝź - TAGąęÇŠ - RSSśŠÔÄ - ??
      Copyright © 2004-2024 上海卓卓网络科技有限公司