参考资料:
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。