码迷,mamicode.com
首页 > 其他好文 > 详细

NULL和唯一约束UNIQUE的对应关系

时间:2017-04-28 11:18:05      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:base   不同   div   sql语法   比较   uniq   rmi   db2   策略   

NULL和唯一约束UNIQUE的对应关系
 
在数据库中,NULL表示列值为空。唯一约束UNIQUE规定指定列的值必须是唯一的,值和值之间都不能相同。这个时候,就出现一个问题,NULL和NULL算是相同,还是不同。由于SQL语法没有明确规定,所以各个数据库厂商的处理方式不同。
 
(1)PostgreSQL和Oracle认为NULL表示没有指定数据,所以数据有多种可能,所以UNIQUE约束列中允许存在任意个NULL。
 
(2)Informix和SQL Server认为NULL就表示空,是一种唯一的状态。所以UNIQUE约束列中只能有一个NULL。
 
(3)DB2、SQLAnyWhere和InterBase认为NULL存在不确定性,无法比较,所以UNIQUE约束列中不允许有NULL。
 
而SQLite遵循了PostgreSQL和Oracle的策略,允许UNIQUE约束列中有任意个NULL。

NULL和唯一约束UNIQUE的对应关系

标签:base   不同   div   sql语法   比较   uniq   rmi   db2   策略   

原文地址:http://www.cnblogs.com/daxueba-ITdaren/p/6780696.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!