Oracle 唯一 约束(unique constraint) 与 索引(index) 关系说明
一. 官网对Unique Constraints说明
http://download.oracle.com/docs/cd/E11882_01/server.112/e16508/datainte.htm#CNCPT1642
uniquekey constraint requires that every value in a column or set of columns beunique. No rows of a table may have duplicate values in a column (the uniquekey) or set of columns (the composite unique key) with a unique key constraint.
Note:
Theterm key refers only to the columns defined in the integrity constraint. Because the database enforces a unique constraint byimplicitly creating or reusing an index on the key columns, the term uniquekey is sometimes incorrectly used as a synonym for unique key constraint orunique index.
--数据库在创建unique constraint的同时,强制创建或者重用列上的索引。如果之前列上没有索引,那么强制创建的索引是unique index,如果列上已经存在索引,就重用之前的索引。
Uniquekey constraints are appropriate for any column where duplicate values are notallowed. Unique constraints differ from primary keyconstraints, whose purpose is to identify each table row uniquely, andtypically contain values that have no significance other than being unique.Examples of unique keys include:
(1)A customer phone number, where the primary key is the customernumber
(2)A department name, where the primary key is the department number
Asshown in Example2-1, a unique key constraint exists on the email column of the hr.employeestable. The relevant part of the statement is as follows:
CREATE TABLE employees ( ...
,email VARCHAR2(25)
CONSTRAINT emp_email_nn NOT NULL ...
,CONSTRAINT emp_email_uk UNIQUE (email) ... );
Theemp_email_uk constraint ensures that no two employees have the same emailaddress, as shown inExample5-1.
Example 5-1 Unique Constraint
SQL> SELECT employee_id, last_name,email FROM employees WHERE email = 'PFAY';
EMPLOYEE_ID LAST_NAME EMAIL
----------- --------------------------------------------------
202 Fay PFAY
SQL> INSERT INTO employees (employee_id,last_name, email, hire_date, job_id)
1 VALUES(999,'Fay','PFAY',SYSDATE,'ST_CLERK');
.
.
.
ERROR at line 1:
ORA-00001:unique constraint (HR.EMP_EMAIL_UK) violated
Unless a NOT NULLconstraint is also defined, a null always satisfies a unique key constraint. Thus,columns with both unique key constraints and NOT NULL constraints are typical.This combination forces the user to enter values in the unique key andeliminates the possibility that new row data conflicts with existing row data.
Note:
Because of the searchmechanism for unique key constraints on multiple columns, you cannot haveidentical values in the non-null columns of a partially null composite uniquekey constraint.
二. 相关测试
2.1 测试unique index 和 uniqueconstraint
SYS@anqing2(rac2)> create table ut(idnumber,phone varchar2(15),name varchar2(15));
Table created.
SYS@anqing2(rac2)> insert into utvalues(1,'13888888888','dave');
1 row created.
SYS@anqing2(rac2)> insert into utvalues(1,'13888888888','dave');
1 row created.
SYS@anqing2(rac2)> insert into utvalues(2,'13899999999','dba');
1 row created.
SYS@anqing2(rac2)> commit;
Commit complete.
--在phone 字段上,我们创建uniqueconstraint
SYS@anqing2(rac2)> alter table ut addconstraint uc_phone unique(phone);
alter table ut add constraint uc_phoneunique(phone)
*
ERROR at line 1:
ORA-02299: cannot validate (SYS.UC_PHONE) -duplicate keys found
--这里报错,因为我们在插入数据的时候,有重复值,先删除掉重复值
SYS@anqing2(rac2)> select * from ut;
ID PHONE NAME
---------- --------------- ---------------
1 13888888888 dave
2 13899999999 dba
1 13888888888 dave
SYS@anqing2(rac2)> delete from ut whererownum=1;
1 row deleted.
SYS@anqing2(rac2)> commit;
Commit complete.
SYS@anqing2(rac2)> select * from ut;
ID PHONE NAME
---------- --------------- ---------------
2 13899999999 dba
1 13888888888 dave
--唯一性约束创建成功
SYS@anqing2(rac2)> alter table ut addconstraint uc_phone unique(phone);
Table altered.
--查看约束
SYS@anqing2(rac2)> selectconstraint_name,constraint_type,table_name,index_owner,index_name fromuser_constraints where table_name = 'UT';
CONSTRAINT_NAME C TABLE_NAME INDEX_OWNER INDEX_NAME
--------------- - -------------------------- -------------
UC_PHONE U UT SYS UC_PHONE
--Oracle 自动创建了索引并关联到约束, 索引名和约束名是相同的。
--验证下索引
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
INDEX_NAME INDEX_TYPE UNIQUENES GENERATED
------------- ------------- -------------------
UC_PHONE NORMAL UNIQUE N
--我们并没有创建索引,而是在创建unique constraint时,oracle 强制创建了uniqueindex。
--现在我们drop index 看看
SYS@anqing2(rac2)> drop index uc_phone;
drop index uc_phone
*
ERROR at line 1:
ORA-02429: cannot drop index used forenforcement of unique/primary key
--这里报错,不能删除unique/primary key 上的索引。在这种情况下,我们只有先删除约束。
SYS@anqing2(rac2)> alter table ut dropconstraint uc_phone;
Table altered.
SYS@anqing2(rac2)> drop index uc_phone;
drop index uc_phone
*
ERROR at line 1:
ORA-01418: specified index does not exist
--再次drop 索引时,提示索引已经不存在,说明已经在删除约束的同时,把索引删掉了。
SYS@anqing2(rac2)> selectconstraint_name,constraint_type,table_name,index_owner,index_name fromuser_constraints where table_name = 'UT';
no rows selected
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
no rows selected
结论:
当约束列上没有索引时,在创建unique constraint 时,oracle 会自动创建unique index,并且该索引不能删除,当删除unique constraint 时,unique index 会自动删除。
2.2 测试unique constraint 和non-unique index
--现在字段phone上创建B-Tree索引
SYS@anqing2(rac2)> create indexidx_ut_phone on ut(phone);
Index created.
--查看索引
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
INDEX_NAME INDEX_TYPE UNIQUENES GENERATED
------------- ------------- -------------------
IDX_UT_PHONE NORMAL NONUNIQUE N
--创建unique constraint
SYS@anqing2(rac2)> alter table ut add constraint uc_phoneunique(phone);
Table altered.
--查看约束和索引信息
SYS@anqing2(rac2)> selectconstraint_name,constraint_type,table_name,index_owner,index_name fromuser_constraints where table_name = 'UT';
CONSTRAINT_NAME C TABLE_NAME INDEX_OWNER INDEX_NAME
--------------- - -------------------------- -------------
UC_PHONE U UT SYS IDX_UT_PHONE
--这里重用了已经存在的索引
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
INDEX_NAME INDEX_TYPE UNIQUENES GENERATED
------------- ------------- -------------------
IDX_UT_PHONE NORMAL NONUNIQUE N
--删除索引
SYS@anqing2(rac2)> drop indexIDX_UT_PHONE;
drop index IDX_UT_PHONE
*
ERROR at line 1:
ORA-02429: cannot drop index used forenforcement of unique/primary key
--这个提示和之前的一样,我们先删除约束,在来查看
SYS@anqing2(rac2)> alter table ut dropconstraint uc_phone;
Table altered.
SYS@anqing2(rac2)> select constraint_name,constraint_type,table_name,index_owner,index_namefrom user_constraints where table_name = 'UT';
no rows selected
--这里约束已经删除掉了。
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
INDEX_NAME INDEX_TYPE UNIQUENES GENERATED
------------- ------------- -------------------
IDX_UT_PHONE NORMAL NONUNIQUE N
--但是我们的索引并在删除约束时删除掉
--在手工删除索引,成功
SYS@anqing2(rac2)> drop indexIDX_UT_PHONE;
Index dropped.
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
no rows selected
--重新把约束和索引加上,然后一次删除
SYS@anqing2(rac2)> create indexidx_ut_phone on ut(phone);
Index created.
SYS@anqing2(rac2)> alter table ut addconstraint uc_phone unique(phone);
Table altered.
SYS@anqing2(rac2)> selectconstraint_name,constraint_type,table_name,index_owner,index_name fromuser_constraints where table_name = 'UT';
CONSTRAINT_NAME C TABLE_NAME INDEX_OWNER INDEX_NAME
--------------- - -------------------------- -------------
UC_PHONE U UT SYS IDX_UT_PHONE
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
INDEX_NAME INDEX_TYPE UNIQUENES GENERATED
------------- ------------- -------------------
IDX_UT_PHONE NORMAL NONUNIQUE N
SYS@anqing2(rac2)> alter table ut drop constraint uc_phone drop index;
Table altered.
SYS@anqing2(rac2)> selectconstraint_name,constraint_type,table_name,index_owner,index_name fromuser_constraints where table_name = 'UT';
no rows selected
SYS@anqing2(rac2)> selectindex_name,index_type,uniqueness,generated from user_indexes wheretable_name='UT';
no rows selected
--索引和约束一次删除
小结:
当我们的列上有索引时,在创建unique constraint时,Oracle 会重用之前的索引,并且不会改变索引的类型,在第一个测试里,Oracle 自动创建的索引是unique index。
当我们删除约束时,关联的索引不会自动删除。 这个问题的MOS 上有说明。 参考MOS [ID309821.1]。
我们可以分两步,先删除约束,在删除索引。 MOS 提供了方法,就是在删除约束时,加上drop index,这样就能一次搞定。
SQL>altertable ut drop constraint uc_phone drop index;
-------------------------------------------------------------------------------------------------------
Blog: http://blog.csdn.net/tianlesoftware
Email: dvd.dba@gmail.com
DBA1 群:62697716(满); DBA2 群:62697977(满) DBA3 群:62697850(满)
DBA 超级群:63306533(满); DBA4 群: 83829929 DBA5群: 142216823
DBA6 群:158654907 聊天 群:40132017 聊天2群:69087192
--加群需要在备注说明Oracle表空间和数据文件的关系,否则拒绝申请
原文出处:
Oracle 唯一 约束(unique constraint) 与 索引(index) 关系说明的更多相关文章
- oracle的约束隐式创建索引和先索引后约束的区别
oracle的约束隐式创建索引和先索引后约束的区别 两种情况:1.对于创建约束时隐式创建的索引,在做删除操作的时候: 9i~11g都会连带删除该索引 2.对于先创建索引,再创建约束(使用到此索引)这种 ...
- NULL和唯一约束UNIQUE的对应关系
NULL和唯一约束UNIQUE的对应关系 在数据库中,NULL表示列值为空.唯一约束UNIQUE规定指定列的值必须是唯一的,值和值之间都不能相同.这个时候,就出现一个问题,NULL和NULL算是相 ...
- 唯一约束 UNIQUE KEY
目录 什么是唯一约束 与主键的区别 创建唯一约束 唯一性验证 什么是唯一约束 Unique Key:它是 MySQL 中的唯一约束,是指在所有记录中字段的值不能重复出现.例如,为 id 字段加上唯一性 ...
- Oracle之唯一性约束(UNIQUE Constraint)使用方法具体解释
Oracle | PL/SQL唯一索引(Unique Constraint)使用方法 1 目标 用演示样例演示怎样创建.删除.禁用和使用唯一性约束. 2 什么是唯一性约束? 唯一性约束指表中一个字段或 ...
- [mysql] 删除唯一约束unique
alter table ot_document drop index title
- hibernate中怎样配置两个联合属性为唯一约束(非联合主键)
Annotation中配置: @Table元素包括了一个schema和一个catalog属性,如果需要可以指定相应的值. 结合使用@UniqueConstraint注解可以定义表的唯一约束(uniqu ...
- Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系
版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...
- mysql,sql server,oracle 唯一索引字段是否允许出现多个 null 值?
最近一个项目,涉及到sql server 2008,因为业务需求,希望建立一个唯一索引,但是发现在sql server中,唯一索引字段不能出现多个null值,下面是报错信息: CREATE UNIQU ...
- MySql -- unique唯一约束
3.UNIQUE 约束 约束唯一标识数据库表中的每条记录. 创建一张测试表 CREATE TABLE `test`.`info`( `id` ) UNSIGNED NOT NULL AUTO_INCR ...
随机推荐
- Handlebars的基本用法
使用Handlebars,你可以轻松创建语义化模板,Mustache模板和Handlebars是兼容的,所以你可以将Mustache导入Handlebars以使用 Handlebars 强大的功能. ...
- java通过StringToKenizer获取字符串中的单词根据空格分离-详情版
public class DaXie { public static void main(String[] args) { String strin = "Hello Java World! ...
- Python使用MySQL数据库(新)(转)
http://www.cnblogs.com/fnng/p/3565912.html 一,安装mysql 如果是windows 用户,mysql 的安装非常简单,直接下载安装文件,双击安装文件一步一步 ...
- setTimeout中调用this
项目案例: 左右切换tab容器的动作,封装到一个对象中: var slidingComp = { startX : 0 , moveX : 0 , ...... start : function(e) ...
- 剖析 GSM 加密机制以及位置更新的过程
你有没有想过打开手机时会发生什么?它是如何以安全的方式与网络进行通信?几乎所有人都知道TCP / IP,并且可能许多人还是专家,但是谈到电信方面,很少有人知道它的内部原理. gsm中的消息结构是什么? ...
- Python 进程池的同步方法
import time from multiprocessing import Process,Pool def f1(n): time.sleep(1) #print(n) return n*n i ...
- 使用 JavaScript 截屏
经常在微博上看到很多内容使用的什么长微博截图,并且截图上还附加了很多其他的信息.之前对纯前端截图有些研究,正好本博客有这个需求,今天就把这东西实现了下. 需要声明的是,JavaScript 目前还不能 ...
- Windows安装Anaconda出现failed to create menus
当出现上述问题时,有以下的解决办法: (1)默认安装,即一直next: (2)安装路径里不要包含英文以外的语言,即安装路径全部用英文命名: (3)先不要安装python,或者将安装的python配置好 ...
- Bootstrap如何禁止响应式布局 不适配
Bootstrap 会自动帮你针对不同的屏幕尺寸调整你的页面,使其在各个尺寸的屏幕上表现良好.下面我们列出了如何禁用这一特性,就像这个非响应式布局实例页面一样. 禁止响应式布局有如下几步: 移除 此 ...
- jq 绑定事件和解绑事件
<!DOCTYPE html><html><head> <script src="http://cdn.static.runoob.com/libs ...