mysql中的字符串判断语句(非空判断替换转换)

方法一.CASE函数

CASE

WHEN value1 THEN returnvalue1

WHEN value2 THEN returnvalue2

WHEN value3 THEN returnvalue3

…… ELSE defaultvalue

END

方法二.IF()函数

CASE函数可以实现非常复杂的逻辑判断,实现满足条件就A,否则就B这样简单的判断逻辑的话,CASE函数就显得臃肿。MYSQL提供了IF()函数用于简化这种逻辑判断,其语法格式如下:IF(condition,A,B)
如果condition条件为真,就返回A,否则返回B。所以如果有多个条件,就无法使用IF函数。IF()返回一个数字或字符串。

if(xingjuriqi='',null,xingjuriqi)

MySQL判断字符串为NULL或者为空字符串

函数名说明
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
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值