IFNULL函数是MySQL控制流函数之一,它接受两个参数,如果不是NULL,则返回第一个参数。 否则,IFNULL函数返回第二个参数。
两个参数可以是文字值或表达式。
一、语法格式
IFNULL(expression_1,expression_2)
如果expression_1不为NULL,则IFNULL函数返回expression_1 否则返回expression_2的结果。
如果要返回基于TRUE或FALSE条件的值,而不是NULL,则应使用IF函数。
二、简单示例
SELECT IFNULL(1,2)       -- returns 1
SELECT IFNULL('',2)        -- returns ''(空字符串也是有值)
SELECT IFNULL(0,2)       -- returns 0(0也是有值)
SELECT IFNULL(NULL,'暂无数据') -- returns '暂无数据'
上述四个示例的结果表明,查询的字段不管是0还是空字符串,都不为null,会原样输出,只有查询的字段为null时,才会使用第二个参数,即自定义的文本或者数字显示。
三、应用场景
当两个表关联查询时,如果A表为主表,B表为关联表,且B表无数据时,如果为null的话我们可以换个文案显示。
例:A表是学生表
CREATE TABLE `student` (
`id` int(11) NOT NULL AUTO_INCREMENT
`nick` VARCHAR(20) NOT NULL
`class_id` INT(11) NOT NULL DEFAULT 0
PRIMARY KEY (`id`) USING BTREE
)
INSERT INTO student(nick, class_id) VALUES ('xiaoming', 1),('xiaohong', 2),('xiaogang', 0)
B表是班级表
CREATE TABLE `class` (
`id` int(11) NOT NULL AUTO_INCREMENT
`name` VARCHAR(20) NOT NULL
PRIMARY KEY (`id`) USING BTREE
)
INSERT INTO class(name) VALUES ('一班'),('二班'),('三班')
当我们关联查询时,已经分过班级的学生显示班级,暂无班级的学生显示暂无班级,这种业务场景下就要使用if null条件
例:SELECT s.id as '学生id',s.nick as '学生昵称',IFNULL(c.name,'暂无班级') as '班级' FROM student s LEFT JOIN class c on s.class_id=c.id
查询结果为:
学生id   学生昵称   学生班级
1          xiaoming    一班
2          xiaohong    二班
3          xiaogang    暂无班级