问题背景:前段时间我在测试过程中上传一个文件,文件内容要求判断为空,结果出现了报错,跟踪原因发现是开发误将oracle中对null的判断方式写成了=null,下面梳理一下不同数据库对该问题的处理方法:

1、mysql

MySQL 中 null 不代表任务实际的值,类似于一个未知数。

2.执行对比

2.1 查询条件为 =null

   执行之后,发现返回行数为0

2.2 查询条件为 is null

执行后发现返回行数为8

2.3两次查询的为何不同

null 在MySQL中不代表任何值,通过运算符是得不到任何结果的,因此只能用 is null(默认情况)

3、oracle

  在oracle中,判断一个字段或者一个变量是否为null 语法是 is null。返回的结果是boolean型
如果使用 = null,会返回null。如果在代码或语句中使用,可能会获取不到结果或者报错
另外,null并不表示不存在,而是未知,我们通常成为“UNKNOWN”

4、DB2

测试使用布尔值来判断与null的比较结果为false,因此column = null的计算结果为false以及column != null,与列的值无关。如果想实际检查一个值是否为空,必须使用column is null

 

结论:如果要判断是否为null,以上三种数据库都使用is null 或者is not null,只有表中真实存储为"null"时,才能用=null查到