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

mysql 存储过程中 num 总是输出 0:为什么 tempsno 变量没有默认值?

%ign%ignore_a_1%re_a_1% mysql 存储过程中的 num 总是输出 0

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

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

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

小鸽子助手 小鸽子助手

一款集成于WPS/Word的智能写作插件

小鸽子助手 55 查看详情 小鸽子助手

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<60) then            if(tSno!=TempSno) then            set Num = Num + 1;            set TempSno = tSno;            end if;        end if;    until done end repeat;    select Num;    close getStudent;    drop table OrderTable;end //delimiter ;call countNum();

修改后,num 将正确输出满足条件的学生人数。

以上就是MySQL 存储过程中 Num 总是输出 0:为什么 TempSno 变量没有默认值?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/739663.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 14:32:51
下一篇 2025年11月25日 14:38:31

相关推荐

发表回复

登录后才能评论
关注微信