1818IP-服务器技术教程,云服务器评测推荐,服务器系统排错处理,环境搭建,攻击防护等

当前位置:首页 - 数据库 - 正文

君子好学,自强不息!

Oracle unique约束的创建步骤

2022-11-23 | 数据库 | admin | 497°c
A+ A-

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

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

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

createtableunique_test 
(idnumber, 
fnamevarchar2(20), 
lnamevarchar2(20), 
addressvarchar2(100), 
emailvarchar2(40), 
constraintname_uniqueunique(fname,lname)) 

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

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

altertableunique_test 
addconstraintemail_uniqueunique(email); 

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

insertintounique_test(id,fname,lname)values(1,’德华’,'刘’)

这一行可以正常的被插入

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

insertintounique_test(id,fname,lname)values(2,’德华’,'刘’)

是会出现如下错误的:

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

但我们如果改为如下值:

insertintounique_test(id,fname,lname)values(2,’学友’,'张’);

又可以正常插入了。

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

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

本文来源:1818IP

本文地址:https://www.1818ip.com/post/11114.html

免责声明:本文由用户上传,如有侵权请联系删除!

发表评论

必填

选填

选填

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。