存储过程复用代码案例——如果english不及格的人超过半数,则给每个人增加2分,循环加,直到不及格的人数少于一半。usp_promoteGrade有一个参数,及格分数线@passline。
create proc usp_promteGrade
@passline int--定义一个可变量的及格分
as
begin
--计算总人数
declare @count2 int = (select COUNT(*) from TblScore)
--计算英语不及格人数
declare @loster int = (select COUNT(*) from TblScore where tsEnglish<@passline)
declare @harfcount int = floor(@count2/2.0)
while @loster>@harfcount
begin
update TblScore set tsEnglish=tsEnglish+2 where tsEnglish<@passline
--set执行
set @loster=(select COUNT(*) from TblScore where tsEnglish<@passline)
end
end
--使用存储过程
exec usp_promteGrade 40--传参数使得及格分数可以自定义