Mysql中IFNULL , ISNULL, NULLIF这三个函数的相爱相杀

本文详细介绍了SQL中用于处理NULL值的三个关键函数:IFNULL()、ISNULL()和NULLIF()。通过实例展示了它们如何在不同场景下工作,帮助理解如何在表达式中处理可能的NULL值。IFNULL()返回非NULL的表达式或备选值,ISNULL()检查表达式是否为NULL并返回布尔值,而NULLIF()在两个表达式相等时返回NULL,否则返回第一个表达式。这些函数在数据库查询和数据处理中非常实用。

IFNULL(expr1,expr2)用法

假如expr1不为NULL,则 IFNULL() 的返回值为expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。

以实际例子查看:

 SELECT  IFNULL(1,0);                    
 SELECT  IFNULL(NULL,10);                            
 SELECT  IFNULL(1/0,10);    
 SELECT  IFNULL(1/0,'yes');  
 SELECT  IFNULL('','yes'); 

执行结果分别是

 

 

 

 

 

 

二、ISNULL(expr) 的用法

    如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。

select isnull(1+1) ; -- 0
select isnull(1/0); -- 1

三、NULLIF(expr1,expr2)用法

    如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1。

   这和CASE  WHEN expr1 = expr2 THEN NULL ELSE   expr1 END相同。   

SELECT NULLIF(1,1); -- NULL
SELECT NULLIF(1,2); -- 1​​​​​​
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程序员路同学

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

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

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

打赏作者

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

抵扣说明:

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

余额充值