T-SQL(2)-逻辑控制

本文介绍使用SQL中的逻辑控制语句解决实际问题的方法,包括利用IF-ELSE语句判断班级成绩情况、WHILE循环语句实现成绩提升逻辑及CASE-END多分支语句进行成绩等级划分。
 

逻辑控制语句

 

1 IFELSE语句

 

问题:

统计并显示本班笔试平均分,如果平均分在70以上,显示成绩优秀,并显示前三名学员的考试信息;如果在70以下,显示本班成绩较差,并显示后三名学员的考试信息

分析:

第一步,统计平均成绩存入临时变量;

第二步,用IFELSE判断;

例子:

DECLARE @myavg float

SELECT @myavg=AVG(writtenExam) FROM stuMarks

print ‘本班平均分’+convert(varchar(5),@myavg) 

if(@myavg>70)

BEGIN

       print ‘本班笔试成绩优秀,前三名的成绩为:

       SELECT TOP 3 * FROM stuMarks ORDER BY writtenExam DESC

END

ELSE

BEGIN

       print ‘本班笔试成绩较差,后三名的成绩为:

       SELECT TOP 3 * FROM stuMarks ORDER BY writtenExam

END

 

2 WHILE循环语句

 

 

问题:

本次考试成绩较差,假定要提分,确保每人笔试都通过。提分规则很简单,先每人都加2分,看是否都通过,如果没有全部通过,每人再加2分,再看是否都通过,如此反复提分,直到所有人都通过为止

分析:

第一步,统计没通过的人数

第二步,如果有人没通过,加分;

第三步,循环判断。

例子:

DECLARE @n int

WHILE(1=1) --条件永远成立

  BEGIN

    SELECT @n=COUNT(*) FROM stuMarks

            WHERE writtenExam<60    --统计不及格人数

    IF (@n>0)

       UPDATE stuMarks     --每人加2

            SET writtenExam=writtenExam+2

   ELSE

       BREAK    --退出循环

  END

print '加分后的成绩如下:'

SELECT * FROM stuMarks

 

3 CASEEND多分支语句

CASE

  WHEN 条件1 THEN  结果1

  WHEN 条件2 THEN  结果2

  ……

  ELSE 其他结果

END

问题:

采用美国的ABCDE五级打分制来显示笔试成绩。

 A:   90分以上

 B:   8089

 C:   7079

 D:   6069

 E:   60分以下

例子:

print  'ABCDE五级显示成绩如下:'

SELECT stuNo,

   成绩= CASE 

                  WHEN writtenExam<60 THEN 'E'

                  WHEN writtenExam BETWEEN 60 AND 69 THEN 'D'

                  WHEN writtenExam BETWEEN 70 AND 79 THEN 'C'

                  WHEN writtenExam BETWEEN 80 AND 89 THEN 'B'

                  ElSE    'A'

              END

      FROM stuMarks

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值