MySQL查询除了某个值外的其他值 且不滤掉NULL

疑问:在学习过程中发现使用 != <> 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。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值