Oracle-主键约束、唯一约束与外键约束
2015-11-24 16:52
323 查看
原文地址:Oracle-主键约束、唯一约束与外键约束 作者:舒风星
1.主键约束: 一个表只能有一个主键约束。主键可以是单个字段,也可以是多个字段。无论是哪种情况,其所有字段都是NOT NULL。
2.Unique约束:一个表可以有多个Unique约束,Unique的字段可以为NULL。
3.主键与Unique:不同点在于一个表只能有一个主键约束,但是可以有多个Unique约束;主键所有字段都是not null,unique可以是null。相同点在于都能保证唯一性。
4.主键、Unique与索引:主键约束与Unique约束默认会成为索引。当主键和Unique有多个字段时,有索引前缀性问题,即where语句中的条件必须有主键或者unique的第一个字段,否则不会使用索引。
5. 外键与主键、Unique:外键必须为另外一张表(父表)的主键或者唯一索引。如果要添加记录,而父表中没有则报错。反之,如果要删除父表中的记录,而子表中有记录,也会报错。但是如果在创建外键约束时,如果使用on delete cascade,则删除父表中数据时,不报错而直接把子表关联的数据删除。如果要删除父表,则需要加上cascade constraints,此时子表的foreign key被去除,表中记录保持不变。
--标红色的部分是外企的一道DBA面试题。其实主键约束和unique约束的区别也可以出一道题。
1.主键约束: 一个表只能有一个主键约束。主键可以是单个字段,也可以是多个字段。无论是哪种情况,其所有字段都是NOT NULL。
2.Unique约束:一个表可以有多个Unique约束,Unique的字段可以为NULL。
3.主键与Unique:不同点在于一个表只能有一个主键约束,但是可以有多个Unique约束;主键所有字段都是not null,unique可以是null。相同点在于都能保证唯一性。
4.主键、Unique与索引:主键约束与Unique约束默认会成为索引。当主键和Unique有多个字段时,有索引前缀性问题,即where语句中的条件必须有主键或者unique的第一个字段,否则不会使用索引。
5. 外键与主键、Unique:外键必须为另外一张表(父表)的主键或者唯一索引。如果要添加记录,而父表中没有则报错。反之,如果要删除父表中的记录,而子表中有记录,也会报错。但是如果在创建外键约束时,如果使用on delete cascade,则删除父表中数据时,不报错而直接把子表关联的数据删除。如果要删除父表,则需要加上cascade constraints,此时子表的foreign key被去除,表中记录保持不变。
--标红色的部分是外企的一道DBA面试题。其实主键约束和unique约束的区别也可以出一道题。
相关文章推荐
- Oracle备份与恢复介绍(物理备份与逻辑备份)
- Oracle中的锁概述
- oracle 添加表分区
- oracle blog
- oracle数据字典详解
- oracle启动和关闭数据库
- Oracle 统计信息(备份/导入)表分析-[注意要刷缓存]
- oracle 10g中的几个概念(表空间,数据库名,实例名,操作系统环境变量SID)
- Oracle位图索引与B-Tree索引的优缺点
- ORACLE中的SQL%ROWCOUNT
- Oracle sqlldr
- Oracle将字符串转换为数字,并替换特殊字符
- Oracle中GOTO的用法
- Linux平台Oracle多个实例启动
- Oracle Enterprise Manager
- linux配置oracle客户端,sqlplus、sqlldr、exp、imp
- oracle删除除空白以外的表数据
- oracle 问题查找 error ora-
- Fedora 安装Oracle 11gR2数据库
- Oracle内连接、左外连接、右外连接、全外连接