mysql里面的while里面为什么会重复输出最后一个数据

MySQL的WHILE循环由于其先执行后判断的机制,可能导致在特定情况下重复输出最后一个数据。当设置的标记变量(tag)在监听语句中被修改时,如SQLSTATE '02000'的处理,会导致FETCH语句失效,进而重复执行SELECT语句。为解决此问题,可以在循环体内加入条件判断,确保只有在标记为0时才执行输出,从而避免重复输出。
摘要由CSDN通过智能技术生成
mysql里面的while运行机制是先执行再判断,当监听语句判断tag=1的时候,while里面的语句会继续执行,但是监听语句里面的tag=1会让fetch语句失效,进而接着执行1select uid语句,所以会输出两次最后一个

eg:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值