sqlserver数据库逻辑控制语句

本文详细介绍了SQL中的IF-ELSE、WHILE及CASE-END三种控制流语句的使用方法,并通过具体实例展示了如何在实际场景中应用这些语句。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//SQL中的IF-ELSE语句
IF (条件)
BEGIN
语句1
语句2
… …
END
ELSE
BEGIN
语句1
语句2
… …
END


例子:
IF (@score > 85)
PRINT '考试等级:' + '优秀'
ELSE IF (@score > 70)
PRINT '考试等级:' + '良好'
ELSE IF (@score > 60)
PRINT '考试等级:' + '中等'
ELSE
PRINT '考试等级:' + '差'

 

 

//SQL中的WHILE语句
WHILE (条件)
BEGIN
语句1
语句2
……
BREAK
END


例子:
DECLARE @n int --不及格人数
WHILE (1 = 1) --条件永远成立
BEGIN
SELECT @n=COUNT(*) FROM Result WHERE SubjectNo=@subNO AND ExamDate=@date AND StudentResult < 60 --统计不及格人数
IF (@n > 0) --每人加2分
UPDATE Result SET StudentResult=StudentResult+2 FROM Result WHERE SubjectNo=@subNO AND ExamDate=@date AND StudentResult < 95
ELSE
BREAK --退出循环
END

 

 


//CASE-END多分支语句
CASE
WHEN 条件1 THEN 结果1
WHEN 条件2 THEN 结果2
……
ELSE 其他结果
END
注意:ELSE表示CASE中所有WHEN条件均不为 TRUE 时返回的结果
如果省略ELSE且WHEN条件都为FALSE时,CASE语句返回NULL

例子:
SELECT 学号=StudentNo, 成绩= CASE
WHEN StudentResult < 60 THEN 'E'
WHEN StudentResult BETWEEN 60 AND 69 THEN 'D'
WHEN StudentResult BETWEEN 70 AND 79 THEN 'C'
WHEN StudentResult BETWEEN 80 AND 89 THEN 'B'
ELSE 'A'
END
FROM Result
INNER JOIN Subject ON Result.SubjectNo=Subject.SubjectNo

转载于:https://www.cnblogs.com/wangzhaofang/p/8297932.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值