Oracle unique约束的创建步骤

数据库 Oracle
以下的文章主要讲述的是在创建表或是创建好表之后,通过修改表的实际方式来对Oracle unique进行创建约束。以下就是正文的主要内容。

以下的文章主要是讲述Oracle中创建unique***约束 (单列和多列)的实际操作方案,Oracle unique约束其实就是用来保证其表里的某一类,或是使表中的某一类组合起来时不重复的一种手段。

我们在可以在创建表时或者创建好后通过修改表的方式来创建Oracle unique约束。

下面是一些创建unique约束的例子:

 

  1. create table unique_test  
  2. (id number,  
  3. fname varchar2(20),  
  4. lname varchar2(20),  
  5. address varchar2(100),  
  6. email varchar2(40),  
  7. constraint name_unique unique(fname,lname))  

 

在这里我们建立了一个表unique_test,并将其中的fname和lname组合起来建立了Oracle中创建unique***约束。

我们也还可以在表创建完成后手动的通过修改表的方式来增加约束,例如:

 

  1. alter table unique_test  
  2. add constraint email_unique unique(email);  

 

下面我们来往表里面插入数据,

 

  1. insert into unique_test(id,fname,lname) values(1,’德华’,'刘’) 

这一行可以正常的被插入

因为我们在建立表时曾把fname和lname联合起来作为一个约束,因为如果我们希望再次插入刘德华,

 

  1. insert into unique_test(id,fname,lname) values(2,’德华’,'刘’) 

是会出现如下错误的:

ORA-00001: 违反***约束条件 (SYS.NAME_UNIQUE)

但我们如果改为如下值:

 

  1. insert into unique_test(id,fname,lname) values(2,’学友’,'张’); 

又可以正常插入了。

有些朋友可能会有疑问,我们不是为email也建立的一个***约束吗?为什么这两行数据都没有为email列赋值,也就是或两行的email列都是空值,而插入也成功了呢?

这是因为一个空值(null)的含义是该列当前的状态是不存在,他永远不可能会与另外一个空值相等。所以也就不存在违反***约束之说了。

以上的相关内容就是对创建表时或者创建好后通过修改表的方式来创建Oracle unique约束的介绍,望你能有所收获。

【编辑推荐】

  1. Oracle case的实际用法总结
  2. Oracle数据库字典的创建与安装
  3. Oracle 函数用法之decode解剖
  4. Oracle RAC配置的3步骤以及配置错误的原因
  5. Oracle字符集讨论的经典版
责任编辑:佚名 来源: 博客园
相关推荐

2009-11-19 15:13:51

Oracle Uniq

2011-04-11 09:39:46

Oracle约束

2010-04-15 14:30:35

Oracle创建

2010-04-01 14:55:04

Oracle约束

2010-09-01 17:13:07

SQL删除约束

2011-05-20 11:33:06

ORACLE索引约束

2009-11-19 15:44:22

Oracle Chec

2010-05-04 14:20:47

Oracle创建数据库

2009-11-04 17:29:49

Oracle创建管理员

2010-04-06 16:12:25

Oracle约束

2011-08-29 13:40:12

Oracle 10g创建表空间

2011-05-26 10:30:12

Oracle数据库约束

2010-10-19 16:26:46

SqlServer唯一

2010-07-06 16:52:17

SQL Server创

2010-02-24 09:47:25

Oracle手动创建数

2009-10-27 17:22:27

2010-04-06 16:36:55

Oracle绑定变量

2010-04-06 15:23:42

Oracle sql

2010-04-08 12:31:03

Oracle死锁进程

2009-06-24 10:26:41

Oracle约束分区表
点赞
收藏

51CTO技术栈公众号