首先对null进行定义:NULL表示的是“a missing unknown value”,而字符串''是一个确定的值。三种数据库对null值的定义都是一样的。

对null值可以按如下8条进行细致理解:

1、等价于没有任何值、是未知数。

2、NULL与0、空字符串、空格都不同,NULL没有分配存储空间。

3、对空值做加、减、乘、除等运算操作,结果仍为空。

4、NULL的处理使用NVL函数。

5、比较时使用关键字用“is null”和“is not null”。

6、空值不能被索引,所以查询时有些符合条件的数据可能查不出来,count(*)中,用nvl(列名,0)处理后再查。

7、排序时比其他数据都大(索引默认是降序排列,小→大),所以NULL值总是排在最后。

8、空字符串:已经分配了存储空间,但是没有存储东西;NULL:没有分配存储空间。

oracle中关于null值处理的函数:

nvl(expr1,expr2);NVL2(expr1,expr2,expr3);decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default);

sqlserver的null值处理函数:

COALESCE(null,0);

ISNULL(null,0);

mysql的null值处理函数:

IFNULL(expr1,expr2);ISNULL(expr);NULLIF(expr1,expr2)。

最后修改:2021 年 10 月 01 日
如果觉得我的文章对你有用,请随意赞赏