ifnull(ifnull函数 oracle)
mysql ifnull() 返回的仍然为空值null,怎么办?
mybatis返回的null类型数据消失,导致前端展示出错。
如果查询出的结果是空值,应当转换成空字符串。当然在前端也能进行判断,但要求后台实现这个功能。
解决方案:
使用如下方法查询:
SELECT?IFNULL(sex,'')?AS sex FROM user?--如果查询到这个sex为null值,那么就赋值成空字符串不过,如果查询语句本身为null,那么返回前端的还是null,这个就要在代码里判断了。
比如:
SELECT IFNULL(sex,'') AS sex FROM user WHERE id=100
这条语句本身的返回结果是null,它也就不会执行IFNULL函数了,最后的返回结果当然也是null。所以方法是在代码中增加判断:
if(ansList == null || ansList.size() == 0){...}
扩展资料
mySql中IFNULL的使用说明:
IFNULL(expr1,expr2)
如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2。IFNULL()返回一个数字或字符串值
具体用法如:现有学生表(tbl_student)和分数表(score),查询学生表的所有字段和学生相对于的英语成绩(english_score)sql如下:
select stu.*,IFNULL(score.english_score,0)?from tbl_student stu,tbl_score score where 1=1 and stu.stu_id=score.stu_id
以上sql中,如果score表中的english_score有值,则IFNULL(score.english_score,0)就显示english_score,否则,显示0。
条件判断函数-CASE WHEN、IF、IFNULL详解
在众多SQL中,统计型SQL绝对是让人头疼的一类,之所以如此,是因为这种SQL中必然有大量的判读对比。而条件判断函数就是应对这类需求的利器。本文重点总结 CASE WHEN 、 IF 、 IFNULL 三种函数。
Case when语句能在SQL语句中织入判断逻辑,类似于Java中的if else语句。
CASE WHEN语句分为简单函数和条件表达式。
1、简单函数
如果字段值等于预期值,则返回结果1,否则返回结果2。
下面通过一个简单的示例来看一下具体用法。
表score:
场景:在score表中,sex为1表示男性,sex=0表示女性,查询时转换成汉字显示。
SQL语句:
结果:
2、条件表达式
CASE的简单函数使用简便,但无法应对较为复杂的场景,这就需要用到条件表达式了,其语法结构如下:
解释一下,语句中的condition是条件判断,如果该判断结果为true,那么CASE语句将返回result,否则返回result2,如果没有ELSE,则返回null。CASE与END之间可以有多个WHEN…THEN…ELSE语句。END表示CASE语句结束。
场景:score 大于等于90为优秀,80-90为良好,60-80为及格,小于60为不及格,用SQL语句统计出每个学生的成绩级别。
SQL:
结果:
3、综合使用
CASE WHEN 和 聚合函数综合使用,能实现更加复杂的统计功能。
先看第1个场景
在下表 score (sex=1为男,sex=0为女)中,统计有多少个男生和女生以及男女生及格的各有多少个。
SQL:
结果:
再看第2个场景
将上面的score表转换为下面形式:
SQL:
结果如下:
IF函数也能通过判断条件来返回特定值,它的语法如下:
expr是一个条件表达式,如果结果为true,则返回result_true,否则返回result_false。
用一个示例演示,还是表score:
使用IF函数:
可以看出,在一些场景中, IF 函数和 CASE WHEN 是有同样效果的,前者相对简单,后者能应对更复杂的判断。
另外,IF函数还可以和聚合函数结合,例如查询班级男生女生分别有多少人:
在Java程序中调用sql语句时,如果返回结果是 null ,是非常容易引发一些意外情况的。
因此,我们希望在SQL中做一些处理,如果查询结果是 null ,就转换为特定的值,这就要用到Mysql中 IFNULL 函数。
首先SQL一般写法是这样的:
使用 IFNULL 改写一下:
但使用 IFNULL 语句,如果 where 条件中的 name 值是不存在的,那么仍将返回 null ,例如:
这时候,需要改写成下面的形式:
在实际应用中,如果你确定 where 条件的值一定存在,使用前者就可以了,否则要用后者。
IFNULL 函数也可以结合聚合使用,例如:
其他, AVG 、 COUNT 等用同样方式处理,而且,无论 where 条件存在不存在,结果都是会返回0的。
END
引用链接:blog.csdn.net/mu_wind/article/details/93976316
mysql ifnull 函数 使用和 if 三目运算
ifnull函数参数解析:第一个参数为 字段的名字,第二个参数为 最终替换成的值。如果 第一个字段的值 为 NULL,查询的结果中 会被 替换成 0.
三目运算:IF(expr1,expr2,expr3) 。如果 expr1是TRUE,则IF()的返回值为expr2; 否则返回值则为expr3
正则解析:如果 第一个 参数中的正则 匹配成功,if() 的值 为 第二个参数的值。否则为 第三个参数的值。
答案(先把 所有 学生的语文成绩 查出来 作为一个 新表,然后 对新表 进行 分组 聚合):
答案: