mysql case 判断null_mysql IF和CASE判断null的问题

warning:

这篇文章距离上次修改已过374天,其中的内容可能已经有所变动。

今天在写存储过程的时候踩了个小坑,这里记录一下

错误的判断

codeCREATE DEFINER=`PING`@`%` PROCEDURE `test`()

BEGIN

#错误的判断

if "344085057" != null then

select "344085057 != null";

else

select "null 不能直接用=和!=比较";

end if;

CASE null

WHEN null THEN

select "null = null";

ELSE

select 'null 不能直接用=和!=比较';

END CASE;

#错误的判断

END

输出null 不能直接用=和!=比较

null 不能直接用=和!=比较

正确的判断

方法一codeCREATE DEFINER=`PING`@`%` PROCEDURE `test`()

BEGIN

#正确的判断

if "344085057" is not null then

select "344085057 is not null";

else

select "null 比较 用is null和is not null";

end if;

CASE

WHEN null is null THEN

select "null is null";

ELSE

select 'null 比较 用is null和is not null';

END CASE;

#正确的判断

END

输出344085057 is not null

null is null

方法二codeCREATE DEFINER=`PING`@`%` PROCEDURE `test`()

BEGIN

#正确的判断

if "344085057" != ifnull(null,"") then

select "344085057 != null";

else

select "null 不能直接用=和!=比较";

end if;

CASE ifnull(null,"")

WHEN ifnull(null,"") THEN

select "null = null";

ELSE

select 'null 不能直接用=和!=比较';

END CASE;

#正确的判断

END

输出344085057 != null

null = null

loading.gifnull.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值