SQL笔记(五) 空值

空值

空值的运算

空值的算术运算

如果一个算术表达式的任一输出为空,则该表达式结果为空。
例如:
表达式:r.A + 5
r.A为空,则该表达式结果为空。

空值的比较运算

SQL将涉及空值的任何比较运算的结果视为unknown

unknown

where子句的谓词中可以对比较结果使用and、or和not的布尔运算。这些布尔运算的定义也被扩展到可处理的unknown值。

  • and: true and unknown结果为unknownfalse and unknown结果为falseunknown and unknown的结果为unknown
  • or : true or unknown结果为truefalse or unknown结果为unknownunknown or unknown的结果为unknown
  • not : not unknown 的结果为unknown。
null 关键字

SQL使用关键字null测试空值。

查询1. 找出instructor关系中salary为空值的所有教师。
select name
from instructor
where salary is null;

同样如果,谓词is not null 所作用的值非空,那么它为真。

某些SQL实现允许使用is unknown 和is not unknown 测试一个表达式结果是否为unknown

空值的集合运算

空值在谓词中和在元组中的区别

比较两个元组对应的属性时,若这两个属性值相等,需要满足条件之一:
1. 这两个属性值非空且相等。
2. 这两个属性值为空。
例如:
{(‘a’ , null), (‘a’ , null)} 这两个元组拷贝被认为是相同的。
使用distinct会保存相同元组的一份拷贝。


在谓词中null = null 会返回unknown
在元组中,所有属性取值相等,就被认为是相同元组,即使某些值为空。上述方式还应有于集合的并、交和差运算


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coding-cat

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值