今天莫名其妙产生了一个bug,手写的sql,根据条件连表查询数据明明数据库对应有数据,可偏偏查出来没有,后面检查了下手写的sql有问题,判断某个字段不为空我写的是!=null,就这样产生了bug.........,后面改成is not null就查出来了!!!于是百度了一下,
解释如下:在mysql中,筛选非空的时候经常会用到is not null和!=null,这两种方法单从字面上来看感觉是差不多的,其实如果去运行一下试试的话差别会很大!
为什么会出现这种情况呢?
null 表示什么也不是, 不能=、>、< … 所有的判断,结果都是false,所有只能用 is null进行判断。
默认情况下,推荐使用 IS NOT NULL去判断,因为SQL默认情况下对!= Null的判断会永远返回0行,但没有语法错误。
如果你一定想要使用!= Null来判断,需要加上这个语句:
set ANSI_NULLS off
这时你会发现IS NOT NULL 和 != null 是等效的。