oracle、sqlserver和mysql数据库大话null值
首先对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)。
本文来源https://www.modb.pro/db/113828
相关文章