Oracle 主键、唯一键与唯一索引的区别

php中文网
发布: 2016-06-07 17:32:12
原创
2104人浏览过

一般,我们看到术语ldquo;索引rdquo;和ldquo;键rdquo;交换使用,但实际上这两个是不同的。索引是存储在数据库中的一个物理结

一般,我们看到术语“索引”和“键”交换使用,但实际上这两个是不同的。索引是存储在数据库中的一个物理结构,键纯粹是一个逻辑概念。键代表创建来实施业务规则的完整性约束。索引和键的混淆通常是由于数据库使用索引来实施完整性约束。

推荐阅读:

Oracle主键约束自动建立索引问题

Oracle 10g删除主键约束后无法删除唯一约束索引问题的模拟与分析

介绍Oracle Virtual Index虚拟索引

Oracle中检查是否需要重构索引

Oracle case when索引 空值索引 位图索引

网趣购物系统多用户升级版
网趣购物系统多用户升级版

多用户升级版完美整合北京网银、NPS支付、云网支付、快钱支付、西部支付,同时完美整合支付宝功能,是目前国内多用户版最优秀的开店平台,新版同时整合Ewebedit编辑器,增加搜索引擎关键词设置等,!多用户升级版与上一版本有着本质的区别,程序无论在功能性、安全性以及用户使用习惯上有了更高的提升。多用户版除了具有普通网店的所有功能之外,同时允许其他用户在此平台上开设店铺,类似淘宝的功能,是目前电子商务领

网趣购物系统多用户升级版 0
查看详情 网趣购物系统多用户升级版

Oracle分析表和索引

Oracle主键约束自动建立索引问题


 
接下来我们看看数据库中的主键约束、唯一键约束和唯一索引的区别。
SQL> select * from v$version;
BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - Production
PL/SQL Release 11.2.0.1.0 - Production
CORE    11.2.0.1.0      Production
TNS for Linux: Version 11.2.0.1.0 - Production
NLSRTL Version 11.2.0.1.0 - Production
 
SQL> create table test (         
  2  id int,
  3  name varchar2(20),
  4  constraint pk_test primary key(id))
  5  tablespace users;
Table created.
 
SQL> select constraint_name, constraint_type from user_constraints;
CONSTRAINT_NAME                C
------------------------------ -
PK_TEST                        P
 
在test表中,我们指定了ID列作为主键,Oracle数据库会自动创建一个同名的唯一索引:
SQL> select index_name, index_type, uniqueness, tablespace_name
  2  from user_indexes
  3  where table_owner='SCOTT'
  4  and table_name = 'TEST';
INDEX_NAME          INDEX_TYPE          UNIQUENES TABLESPACE_NAME
-------------------- -------------------- --------- ------------------------------
PK_TEST              NORMAL              UNIQUE    USERS
 
此时,如果我们再试图在ID列上创建一个唯一索引,Oracle会报错,因为该列上已经存在一个唯一索引:
SQL> create unique index idx_test_uk on test(id);
create unique index idx_test_uk on test(id)
                                        *
ERROR at line 1:
ORA-01408: such column list already indexed
 
即使创建非唯一索引也不行:
SQL> create index idx_test_id on test(id);
create index idx_test_id on test(id)
                                *
ERROR at line 1:
ORA-01408: such column list already indexed
 
那么唯一键约束的情况是怎样的呢?
SQL> drop table test purge;
Table dropped.
 
SQL> create table test(
  2  id int,
  3  name varchar2(20),
  4  constraint uk_test unique(id));
Table created.
 
SQL> select constraint_name, constraint_type from user_constraints;
CONSTRAINT_NAME                C
------------------------------ -
UK_TEST                        U
 
查看此时的索引情况:
SQL> select index_name, index_type, uniqueness, tablespace_name
  2  from user_indexes
  3  where table_owner='SCOTT'
  4  and table_name = 'TEST';
INDEX_NAME          INDEX_TYPE          UNIQUENES TABLESPACE_NAME
-------------------- -------------------- --------- ------------------------------
UK_TEST              NORMAL              UNIQUE    USERS
Oracle同样自动创建了一个同名的唯一索引,而且也不允许再在此列上创建唯一索引或非唯一索引。
 
我们知道,主键约束要求列值非空(NOT NULL),那么唯一键约束是否也要求非空呢?
SQL> insert into test values(1, 'Sally');
1 row created.
 
SQL> insert into test values(null, 'Tony');
1 row created.
 
SQL> insert into test values(null, 'Jack');
1 row created.
 
SQL> select * from test;
        ID NAME
---------- --------------------
        1 Sally
          Tony
          Jack
 
从实验结果来看,唯一键约束并没有非空要求。
 
接下来我们看看唯一索引对列值的非空要求有什么不同。
 
SQL> drop table test purge;
Table dropped.
 
SQL> create table test(
  2  id int,
  3  name varchar2(20));
Table created.
 
SQL> create unique index idx_test_id on test (id);
Index created.
 
SQL> insert into test values(1, 'Sally');
1 row created.
 
SQL> insert into test values(null, 'Tony');
1 row created.
 
SQL> insert into test values(null, 'Jack');
1 row created.
 
SQL> select * from test;
        ID NAME
---------- --------------------
        1 Sally
          Tony
          Jack
 
通过实验,我们看出唯一索引与唯一键约束一样对列值非空不做要求。

 

继续阅读本文的精彩内容请看第2页

linux

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号