为什么 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>
登录后复制
© 版权声明
文章版权归作者所有,未经允许请勿转载。
【小浪云服务商 - 服务器12元起 - 挂机宝5元起】
THE END
暂无评论内容