Oracle数据库唯一约束和唯一索引的区别详解_Oracle_数据库_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 数据库 > Oracle > Oracle数据库唯一约束和唯一索引的区别详解

Oracle数据库唯一约束和唯一索引的区别详解

 2013/8/10 1:22:13    程序员俱乐部  我要评论(0)
  • 摘要:Oracle数据库唯一约束和唯一索引的区别是本文我们主要介绍的内容,在使用TOAD来操作Oracle数据库时,会注意到创建约束时有PrimaryKey、Check、Unique和ForeignKey四种类型的约束,这与SQLServer中的约束没有什么区别,这里的Check约束除了用于一般的Check约束外,在Oracle中也用于非空约束的实现。也就是说如果一个字段不允许为空,则系统将会创建一个系统的Check约束,该约束定了某字段不能为空。498)this.width=498
  • 标签:详解 ORA 索引 区别 数据库 数据 Oracle Oracle数据库 唯一约束 约束

Oracle数据库唯一约束唯一索引的区别是本文我们主要介绍的内容,在使用TOAD来操作Oracle数据库时,会注意到创建约束时有Primary Key、Check、Unique和Foreign Key四种类型的约束,这与SQL Server中的约束没有什么区别,这里的Check约束除了用于一般的Check约束外,在Oracle中也用于非空约束的实现。也就是说如果一个字段不允许为空,则系统将会创建一个系统的Check约束,该约束定了某字段不能为空。

class='fit-image' onload='javascript:if(this.width>498)this.width=498;' onmousewheel = 'javascript:return big(this)' border="0" alt="Oracle数据库唯一约束和唯一索引的区别详解" width="509" height="486" src="http://images.51cto.com/files/uploadimg/20110818/1127570.png" />

除了约束,还有另外一个概念是索引,在TOAD中创建索引的界面如下:

Oracle数据库唯一约束和唯一索引的区别详解

我们可以注意到在唯一性组中有三个选项:不唯一、唯一和主键。那么创建索引时的唯一、主键与创建约束时候的唯一约束和主键约束有什么区别呢?

这里的可能容易产生误解,其实创建主键的结果是一样的,不管是在创建约束时创建还是创建索引时创建,都会创建一个主键约束和对应的一个唯一索引。

创建唯一约束与创建唯一索引有所不同:

创建唯一约束会在Oracle中创建一个Constraint,同时也会创建一个该约束对应的唯一索引。

创建唯一索引只会创建一个唯一索引,不会创建Constraint。

也就是说其实唯一约束是通过创建唯一索引来实现的。对于前端开发人员来说这两者有什么区别吗?好像没有。都是不能插入重复的值。在删除时这两者也有一定的区别,删除唯一约束时可以只删除约束而不删除对应的索引,所以对于的列还是必须唯一的,而删除了唯一索引的话就可以插入不唯一的值。

关于Oracle数据库唯一约束和唯一索引的区别就介绍到这里了,希望本次的介绍能够对您有所收获!

发表评论
用户名: 匿名