存储过程

存储过程复用代码案例——如果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--传参数使得及格分数可以自定义

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值