暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

oracle、sqlserver和mysql数据库大话null值

数据库精要 2021-09-26
995

      首先对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)。


如需学习更多数据库知识,请扫码关注作者知识星球。365天,天天不间断。

好好学习,365天天向上。


文章转载自数据库精要,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论