MySQL 的IFNULL()函数的作用

在使用left join等联表查询时,常遇到某些字段为null,一般都在后台语言使用if (a==null) 判断做处理,其实MySQL本身也有一个IFNULL函数可以处理。同时我们也来说说ISNULL()和NULLIF()函数。

一、IFNULL(expr1,expr2)用法
假如expr1不为NULL,则 IFNULL() 的返回值为expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。
mysql> SELECT IFNULL(1,0);
-> 1
mysql> SELECT IFNULL(NULL,10);
-> 10
mysql> SELECT IFNULL(1/0,10);
-> 10
mysql> SELECT IFNULL(1/0,‘yes’);
-> ‘yes’
IFNULL(expr1,expr2)的默认结果值为两个表达式中更加“通用”的一个,顺序为STRING、REAL或 INTEGER。


二、ISNULL(expr) 的用法

如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。 
mysql> select isnull(1+1);
                   -> 0
mysql> select isnull(1/0);
                   -> 1
使用= 的null 值对比通常是错误的。

三、NULLIF(expr1,expr2)用法
如果expr1 = expr2 成立,那么返回值为NULL,否则返回值为expr1。这和CASE WHEN expr1 = expr2 THEN NULL ELSE expr1 END相同。
mysql> SELECT NULLIF(1,1);
-> NULL
mysql> SELECT NULLIF(1,2);
-> 1
如果参数不相等,则 MySQL 两次求得的值为 expr1。


  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQLIFNULL函数用于判断一个表达式是否为NULL,如果是NULL则返回指定的替代值。\[1\]例如,如果第一个参数为NULL,则返回第二个参数。如果第一个参数不为NULL,则返回第一个参数的值。\[1\]在示例中,IFNULL(NULL, "World")的结果是"World",IFNULL("Hello", "World")的结果是"Hello"。\[1\] 在另一个示例中,IFNULL函数可以用于查询第二高的薪水。\[2\]通过子查询获取薪水表中第二高的薪水,如果不存在第二高的薪水,则返回NULL。\[2\] 另外,IFNULL函数还可以用于导入数据时的处理。例如,在创建一个学生成绩表时,可以使用IFNULL函数NULL值替换为指定的默认值。\[3\]这样可以确保表中的数据不会出现NULL值。 总之,MySQLIFNULL函数是一个非常有用的函数,可以用于处理NULL值并提供替代值。 #### 引用[.reference_title] - *1* *3* [[Mysql] IFNULL函数](https://blog.csdn.net/Hudas/article/details/123754522)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [MySQLIFNULL()函数](https://blog.csdn.net/zyf11234567/article/details/124597319)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值