疑问:在学习过程中发现使用 != <> NOT IN 这些都会过滤掉有NULL的数据
任务:查询除了某个值外的其他值 且不滤掉NULL
解决:使用IFNULL()函数
例子:查询除了manager_id为100外的其他部门信息,且manager_id包含NULL
SELECT *
FROM departments
WHERE IFNULL(manager_id,'')!='100'
IFNULL()函数介绍
IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
IFNULL() 函数语法格式为:
IFNULL(expression, alt_value)
expression参数 是指要测试的值
alt_value参数 是指当expression 表达式为 NULL 时返回的值
例:
SELECT IFNULL(NULL,'hi')
第一个参数为NULL,输出第二个参数 hi
SELECT IFNULL('hello','hi')
第一个参数不为NULL,输出hello
拓展总结(可能有误):
IFNULL()函数放在查询语句不同位置含义不同,如select后、where后等,并与NULL有关才有意义。
放在select后时,如上诉情况则返回第一或第二个参数,加条件查询则为判断,true返回1,false返回0。
放在where后则作为查询条件(单纯使用!= <> IN NOT IN 这些都会过滤掉有NULL的数据),查询等于或不等于什么。第一个参数不是NULL时必定会输出值,是NULL时,若查询等于什么则没有意义 ,这样并不需要使用该函数 ;查询不等于什么,则返回排除不等于的值外所有的值 包括NULL,但第二个参数的值并不会被用上,是NULL的直接返回NULL。