NULL表示为空值,YashanDB中将空字符串同样视作NULL处理,NULL并不作为确定的值使用,而表示该值处于未知状态或不具有意义。

仅支持在未定义为NOT NULL或PRIMARY KEY约束限制的列中使用NULL。

YashanDB对SQL内置函数中给定参数为NULL的处理结果请查阅内置函数

如需判断是否为NULL,请使用比较运算符IS NULL进行判断,当操作数为NULL时,结果返回TRUE,否则返回FALSE。

NULL表示空值,即缺少数据,因此无法与其他值(包括NULL)进行比较,当使用= != 等运算符进行比较时,结果会返回FALSE。

运算中的NULL


YashanDB中算数运算及位运算中所有NULL参与运算的结果均为NULL,部分比较运算、逻辑运算及连接运算的返回结果根据给定的操作数返回不同结果,详见下表:

运算运算符NULL参与运算
算数运算+结果为NULL
-结果为NULL
*结果为NULL
/结果为NULL
%结果为NULL
比较运算\=结果为FALSE
!= 或 <>结果为FALSE
\>结果为FALSE
\>=结果为FALSE
<结果为FALSE
<=结果为FALSE
[NOT] ININ:

* 左边数据为NULL:结果为FALSE
* 右边集合包含NULL:如果集合中有非NULL值与左边数据相等,则结果为TRUE,否则为FALSE
NOT IN:
* 左边数据为NULL:结果为FALSE
* 右边集合包含NULL:如果集合中含有NULL值,则返回FALSE;如果集合中不含NULL值,且所有数据与左边数据不相等,则结果为TRUE,否则为FALSE |
| | [NOT] LIKE | 结果为FALSE |
| | [NOT] BETWEEN AND | 结果为FALSE |
| | IS [NOT] NULL | IS NULL:
* 操作数为NULL:结果为TRUE
* 操作数不为NULL:结果为FALSE
IS NOT NULL:
* 操作数为NULL:结果为FALSE
* 操作数不为NULL:结果为TRUE |
| 逻辑运算 | AND | 结果为NULL |
| | OR | * TRUE OR NULL:结果为TRUE
* FALSE OR NULL:结果为NULL
* NULL OR NULL:结果为NULL |
| | NOT | 结果为NULL |
| 连接运算 | || | 任何数据||NULL:结果为任何数据 |
| 位运算 | & | 结果为NULL |
| | | | 结果为NULL |
| | ^ | 结果为NULL |


YashanDB
1 声望0 粉丝

崖山数据库系统YashanDB是深圳计算科学研究院自主设计研发的新型数据库管理系统,融入原创的有界计算、近似计算、并行可扩展和跨模融合计算理论,可满足金融、政企、能源等关键行业对高性能、高并发及高安全性的...