mysql 存储过程赋值问题以及mysql 中 ifnull 使用

存储过程赋值问题

  1. mysql 存储过程 经常需要将查询的某个字段值赋给变量,这种方法网络很多请百度。。

  2. 但如果将null 值赋给 变量,就会出现无法把控的问题:
    例如: 在遍历游标的循环中,将null 值赋给 变量,那么会直接跳出循环,且存储过程不报错

  3. 解决方法使用 IFNULL 如下:(这种方法只是解决库中有这条数据但emp_no 为空)

    select  IFNULL(emp_no,'01') from employee where id ='6efdeed79c964740bcc8430a78422179';

问题:查询表中的数据为空设置为自定义值,但是如果无记录,使用IFNULL也非返回无记录。
实例:在这里插入图片描述
解决方法:使用max() 或者 min() 方法完美解决,如图:
在这里插入图片描述
4. mysql 存储过程遍历游标中,如果给变量赋值为空造成循环跳出,如图:在这里插入图片描述
项目中有数据丢失,只是看存储过程逻辑,没有任何问题。。。。不知不觉一晚上的时间就没了。。。
当静下心一步步测试,发现注释掉3上面两行,完美运行,不说了一把辛酸泪哎。。。

希望能帮到各位农友,欢迎留言指正。。。

资料
请关注微信公众号(回复以下关键子),免费领取相关资料;掌握了解相关技术栈
区块链;
go语言;
pdf编辑器;
设计必备软件
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奔跑的小番茄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值