MySQL 存储过程中 Num 总是输出 0:为什么 TempSno 变量没有默认值?

MySQL 存储过程中 Num 总是输出 0:为什么 TempSno 变量没有默认值?

为什么 mysql 存储过程中的 num 总是输出 0

使用存储过程来统计特定条件的学生人数时,遇到的问题是输出的 num 永远为 0。这是因为在声明存储过程变量时缺少默认值。

具体来说,当声明变量 tempsno 时没有指定默认值。当从 sc 表中获取 student 编号 (sno) 和分数 (score) 时,tempsno 的值保持为 null。因此,当比较 tsno 和 tempsno 时,始终返回 NULL,无法进入统计条件的 if 语句块。

要解决此问题,需要在声明 tempsno 变量时添加默认值,例如:

declare tempsno varchar(30) default '';
登录后复制

通过设置默认值,存储过程可以正确跟踪从 sc 表中获取的 sno,并在满足条件时正确增加 num。修改后的存储过程如下:

begin     declare tSno varchar(30);     declare tScore numeric(10,2);     declare TempSno varchar(30) default '';     declare done int default 0;         declare Num int default 0;     declare getStudent cursor for select Sno, Score from SC order by Sno;     declare continue handler for SQLSTATE '02000' set done = 1;     open getStudent;         repeat         fetch getStudent into tSno,tScore;         if(tScore<p>修改后,num 将正确输出满足条件的学生人数。</p>
登录后复制

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容