mysql判断非空的函数与应用场景

参考资料:
mysql中的字符串判断语句(非空判断替换转换)
mysql的coalesce使用技巧

一、判断非空的函数名

函数名说明
ISNULL(expr)如果expr为null返回值1,否则返回值为0
IFNULL(expr1,expr2)如果expr1值为null返回expr2的值,否则返回expr1的值
NULLIF(expr1,expr2)如果expr1==expr2返回值为null,否则返回expr1的值;相当于case when expr1=expr2 then null else expr1 end
COALESCE返回传入的参数中第一个非null的值
IF(expr1,expr2,expr3)如果expr1的值为true,则返回expr2的值,否则返回expr3的值

例:
查找学生姓名不为null的学生信息

SELECT * FROM student WHERE ISNULL(stu_name) <1
SELECT * FROM student WHERE stu_name is not null
查询学生成绩,若score为null则返回0

SELECT IFNULL(‘score’,0) FROM stu_score
SELECT COALESCE(‘score’,0) FROM stu_score
SELECT IF(IFNULL(‘score’,null)=null,0,score) FROM stu_score
SELECT CASE WHEN score is null THEN 0 ELSE score END AS score FROM stu_score

1.1、coalesce的使用技巧

这个参数使用的场合为:假如某个字段默认是null,你想其返回的不是null,而是比如0或其他值,可以使用这个函数
SELECT COALESCE(字段名,0) as value from t;//(如果数据库提成字段默认值不是为0值的话肯定是开发那个的错,个人观点请勿喷哈)。

二、case when then

case when then 是解决复杂的逻辑的,如果是简单的判断,就需要这么复杂了。可以使用if()函数。

三、if函数

if(a,b,c)
如果表达是a成立,就返回值b,否则返回c。

  • 1
    点赞
  • 5
    收藏
  • 打赏
    打赏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
评论

打赏作者

一觉睡到小小时候

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

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

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

打赏作者

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

抵扣说明:

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

余额充值