oracle添加unique,Oracle unique约束的创建步骤

本文详细介绍了如何在Oracle数据库中创建和应用unique约束,包括单列和多列约束的实例,以及为何空值不会违反unique约束。重点展示了通过表创建和修改来实现约束的过程,并解释了空值在unique约束中的特殊情况。
摘要由CSDN通过智能技术生成

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

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

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

create table unique_test

(id number,

fname varchar2(20),

lname varchar2(20),

address varchar2(100),

email varchar2(40),

constraint name_unique unique(fname,lname))

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

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

alter table unique_test

add constraint email_unique unique(email);

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

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

这一行可以正常的被插入

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

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

是会出现如下错误的:

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

但我们如果改为如下值:

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

又可以正常插入了。

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

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

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

【编辑推荐】

【责任编辑:孙巧华 TEL:(010)68476606】

点赞 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值