T-SQL(2)-逻辑控制

逻辑控制语句
 
1 IF ELSE 语句
 
问题:
统计并显示本班笔试平均分,如果平均分在 70 以上,显示 成绩优秀 ,并显示前三名学员的考试信息;如果在 70 以下,显示 本班成绩较差 ,并显示后三名学员的考试信息
分析:
第一步,统计平均成绩存入临时变量;
第二步,用 IF ELSE 判断;
例子:
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 CASE END 多分支语句
CASE
  WHEN 条件 1 THEN  结果 1
  WHEN 条件 2 THEN  结果 2
  ……
  ELSE 其他结果
END
问题:
采用美国的 ABCDE 五级打分制来显示笔试成绩。
 A :   90 分以上
 B :   80 89
 C :   70 79
 D :    60 69
 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

你可能感兴趣的:(数据库,职场,t-sql,休闲,逻辑控制)