【Oracle】Oracle约束的总结
你对ORACLE约束的了解如何?比较模糊还是相当透彻?如果你对下面几个问题了如指掌的话,恭喜你,你已经对约束掌握得比较好了,不用看这篇文章了。ORACLE的约束有啥功能作用? 有哪些类型约束(不同版本ORACLE是否不同)?视图有约束吗?约束是否会影响SQL性能? 约束信息存储在哪些系统视图、数据字典中?约束能否修改名称?能否禁用约束?延迟约束有啥好处.......
约束定义
约束是强加在表上的规则或条件。确保数据库满足业务规则。保证数据的完整性。当对表进行DML或DDL操作时,如果此操作会造成表中的数据违反约束条件或规则的话,系统就会拒绝执行这个操作。约束可以是列一级别的 也可以是表级别的。定义约束时没有给出约束的名字,ORACE系统将为该约束自动生成一个名字,其格式为SYS_Cn,其中n为自然数(强烈建议各位在创建表或增加约束时,给约束定义名称。).
约束功能
约束的功能:实现一些业务规则,防止无效的垃圾数据进入数据库,维护数据库的完整性(完整性指正确性与一致性)。从而使数据库的开发和维护都更加容易。
约束分类
约束分为6类: 非空(NOT NULL)约束、 唯一(UNIQUE)约束、主键(PRIMARY KEY)约束、外键(FOREIGN KEY)约束、条件(CHECK)约束、REF约束。
非空(NOT NULL)约束:顾名思义,所约束的列不能为NULL值。否则就会报错
唯一(UNIQUE)约束:在表中每一行中所定义的这列或这些列的值都不能相同。必须保证唯一性。否则就会违法约束条件。
主键(PRIMARY KEY)约束:唯一的标识表中的每一行,不能重复,不能为空。 创建主键或唯一约束后,ORACLE会自动创建一个与约束同名的索引(UNIQUENES为UNIQUE唯一索引)。需要注意的是:每个表只能有且有一个主键约束。
外键(FOREIGN KEY)约束:用来维护从表(Child Table)和主表(Parent Table)之间的引用完整性. 外键约束是个有争议性的约束,它一方面能够维护数据库的数据一致性,数据的完整性。防止错误的垃圾数据入库; 另外一方面它会增加表插入、更新等SQL性能的额外开销,不少系统里面通过业务逻辑控制来取消外键约束。例如在数据仓库中,就推荐禁用外键约束。
条件(CHECK)约束:表中每行都要满足该约束条件。条件约束既可以在表一级定义也可以在列一级定义。在一列上可以定义任意多个条件约束。
REF约束的定义:REF column
by definition references an object in another object type or in a
relational table. A REF constraint lets you further describe the
relationship between the REF column and the object it references.
ORACLE 11 数据库的约束类型如下:
ORACLE 10 数据库的约束类型如下:
在oracle 官方文档http://docs.oracle.com/cd/B19306_01/server.102/b14237/statviews_1037.htm下
C (check constraint on a table)
P (primary key)
U (unique key)
R (referential integrity)
V (with check option, on a view)
O (with read only, on a view)
http://docs.oracle.com/cd/B28359_01/server.111/b28286/clauses002.htm
http://docs.oracle.com/cd/B28359_01/server.111/b28320/statviews_1044.htm#REFRN20047
C Check constraint on a table
P Primary key
U Unique key
R Referential integrity
V With check option, on a view
O With read only, on a view
H Hash expression
F Constraint that involves a REF column
S Supplemental logging
对于H、S类型,尚不清楚情况,而且从上面我在11g数据库实验结果看,也没发现这两种类型。(有了解的朋友可以告知一二)
约束命名规范
约束名称建议自己定义一套命名规则,否则使用系统生成的约束名,很难能把它和对应的表、字段联系起来。
非空约束 NN_表名_列名
唯一约束 UK_表名_列名
主键约束 PK_表名
外键约束 FK_表名_列名
条件约束 CK_表名_列名
默认约束 DF_表名_列名
如果约束名称超过32位长度,建议应该缩写表名,而不应用NN_表名_数字。不过具体视情况而定,很多时候 DF_表名_列名 这样命名,往往超出了32字符。所以有时候需要缩写表面或是采用其它规则。
约束操作
约束管理
创建各类约束
先看一下如何创建主键约束
CREATE TABLE "DM"."DEPT"
(
"DEPTNO" NUMBER(2,0) PRIMARY KEY,
"DNAME" VARCHAR2(14),
"LOC" VARCHAR2(13)
) TABLESPACE "TBS_DM_DAT" ; COMMENT ON TABLE "DM"."DEPT" IS '部门表'; COMMENT ON COLUMN "DM"."DEPT"."DEPTNO" IS '部门编号'; COMMENT ON COLUMN "DM"."DEPT"."DNAME" IS '部门名称'; COMMENT ON CLOUMN "DM"."DEPT"."LOC" IS '部门所在地方';
此时它的约束名称是系统创建的。如图所示:
如果我们以下面的脚本创建,此时约束如下所示
1 CREATE TABLE "DM"."DEPT"
2 (
3 "DEPTNO" NUMBER(2,0) ,
4 "DNAME" VARCHAR2(14) ,
5 "LOC" VARCHAR2(13) ,
6 CONSTRAINT "PK_DEPT" PRIMARY KEY ("DEPTNO") USING INDEX TABLESPACE TBS_DM_IN
7 ) TABLESPACE "TBS_DM_DAT" ;
8
9
10
11
12 COMMENT ON TABLE "DM"."DEPT" IS '部门表';
13
14 COMMENT ON COLUMN "DM"."DEPT"."DEPTNO" IS '部门编号';
15
16 COMMENT ON COLUMN "DM"."DEPT"."DNAME" IS '部门名称';
17
18 COMMENT ON CLOUMN "DM"."DEPT"."LOC" IS '部门所在地方';
19
如果一个表的约束类型比较多,你会看到一堆SYS_CN这样的约束,如果不仔细核对后面的字段,很难一眼看出约束类型、约束对应字段。
主键约束的限制
通过alter 添加表的主键:
alter table 表名
add constraint PK_xxx_xxx primary key (字段);
文档原文如下: (翻译在下)
Restrictions on Primary Key Constraints Primary constraints are subject to the following restrictions:
A table or view can have only one primary key.
一个表或视图有且只有一个主键
None of the columns
in the primary key can be LOB, LONG, LONG RAW, VARRAY, NESTED TABLE,
BFILE, REF, TIMESTAMP WITH TIME ZONE, or user-defined type. However, the
primary key can contain a column of TIMESTAMP WITH LOCAL TIME ZONE.
主键字段不能为LOB、LOG、LOG
RAW、VARRAY、NESTED TABLE、BFILE、REF、TIMESTAMP WITH TIME
ZONE或用户定义类型。然而它可以包含TIMESTAMP WITH LOCAL TIME ZONE类型的字段。
The size of the primary key cannot exceed approximately one database block.
主键大小不能超过一个数据块大小。
A composite primary key cannot have more than 32 columns.
主键组合键不能超过32列。
You cannot designate the same column or combination of columns as both a primary key and a unique key.
你不能指定一列或组合列既是主键又是唯一键。
You cannot specify a
primary key when creating a subview in an inheritance hierarchy. The
primary key can be specified only for the top-level (root) view.
创建一个继承层次结构中的子视图时,你不能指定一个主键。主键可以唯一指定的顶层(根)视图。
外键约束
外键约束设计的概念:外键约束涉及到两张表,一张是父表,另一张是子表。定义了外键字段的表叫做子表,外键字段的取值受限于父表字段中的值,外键字段的取值要么取NULL值,要么取父表字段对应的值。
插入值的顺序:先插入父表字段中的值,再插入子表字段的值。除非子表字段的值取为null。
drop table table_name cascade constraints;
如果两个表存在父子键关系,在删除表格的时候必须先删除子表,再删除父表。使用cascade constraints可以强制删除,也就是可以直接删除父表。
ALTER TABLE childTable
ADD CONSTRAINT FK_xxxx_xxx
FOREIGN KEY(columnName)
REFERENCES parentTalbe(primaryKeyColumn) [ON DELETE CASCADE|SET NULL];
ON DELETE SET NULL子句:当主表中的一行数据被删除时,Oracle系统会自动地将所有从表中依赖于它的数据记录的外键改成空值;
ON DELETE CASCADE:当主表中的一行数据被删除时,Oracle系统会自动地将所有从表中依赖于它的数据记录删除;
注:如果在外键定义中使用了ON DELETE SET NULL 或ON DELETE CASCADE,无论删除操作是在父表这一端还是子表这一端都不会产生违反引用完整性的问题,但是却留下了安全隐患。这两个子句要谨慎使用,只有在不得已时使用,谨记谨记!!!
外键约束对DML与DDL的影响:
INSERT:只有操作是在子表或从表这一端时才会产生违反引用完整性约束的问题,父表则不然。
DELETE:只有操作是在父表或主表这一端时才会产生违反引用完整性约束的问题,子表则不然。
UPDATE:子表父表直接操作都会违反引用完整性约束。两种解决方法:
1)先更新子表的引用列为空,再更新父表的主键的列的值,然后把子表的引用列更新成新的父表的值;
2)使用ON DELETE SET NULL,先更新父表,然后将子表外键为空的记录更新为新的值。
DDL语句:DROP TABLE与TRUNCATE TABLE,操作父表,违反引用完整性约束,子表则不然。
外键约束的限制:
Restrictions on Foreign Key Constraints Foreign key constraints are subject to the following restrictions:
None of the columns
in the foreign key can be of LOB, LONG, LONG RAW, VARRAY, NESTED TABLE,
BFILE, REF, TIMESTAMP WITH TIME ZONE, or user-defined type. However, the
primary key can contain a column of TIMESTAMP WITH LOCAL TIME ZONE.
外键字段不能为LOB,
LONG, LONG RAW, VARRAY, NESTED TABLE, BFILE, REF, TIMESTAMP WITH TIME
ZONE, or user-defined type类型,主键可以包含数据类型为TIMESTAMP WITH LOCAL TIME
ZONE的字段。
The referenced unique or primary key constraint on the parent table or view must already be defined.
引用唯一或主键约束,必须是父表中已经定义的。
A composite foreign key cannot have more than 32 columns.
外键的组合列不能超过32列。
The child and parent
tables must be on the same database. To enable referential integrity
constraints across nodes of a distributed database, you must use
database triggers. See CREATE TRIGGER.
字表和父表必须在同一个数据库。分布式数据库中,外键不能跨节点,但触发器可以
If
either the child or parent object is a view, then the constraint is
subject to all restrictions on view constraints. See "View Constraints".
You cannot define a
foreign key constraint in a CREATE TABLE statement that contains an AS
subquery clause. Instead, you must create the table without the
constraint and then add it later with an ALTER TABLE statement.
你不能在CREATE TABLE语句中包含AS子查询子句定义一个外键约束。相反,你必须创建一个没有约束的表,然后添加ALTER TABLE语句。
加上一些类似其它约束的限制.
条件约束
非空约束
非空约束的限制:
1: 你不能在视图约束上指定字段为NULL或NOT NULL值
2: 你不能指定一个对象的属性为NULL或NOT NULL。相反,而应使用的IS [NOT] NULL条件CHECK约束
条件约束中的条件与查询语句中的条件相同,但是不能包括以下内容:
1)CURRVAL,NETXTVAL,LEVEL和ROWNUM这样的伪列(PSEUDOCOLUMNS);
2)引用其它行中值的查询语句;
3)SYSDATE,USER,USERENV和UID的函数调用。
文档原文如下:
Restrictions on NOT NULL Constraints NOT NULL constraints are subject to the following restrictions:
You cannot specify NULL or NOT NULL in a view constraint.
You cannot specify
NULL or NOT NULL for an attribute of an object. Instead, use a CHECK
constraint with the IS [NOT] NULL condition.
唯一约束
唯一约束的限制:
文档原文如下:
Restrictions on Unique Constraints Unique constraints are subject to the following restrictions:
None of the columns
in the unique key can be of LOB, LONG, LONG RAW, VARRAY, NESTED TABLE,
OBJECT, REF, TIMESTAMP WITH TIME ZONE, or user-defined type. However,
the unique key can contain a column of TIMESTAMP WITH LOCAL TIME ZONE.
当字段类型为LOB、LOG、LONG RAW、 VARRAY、NESTED TABLE、OBJECT、REF、TIMESTAMP、用户定义类型时,不能在字段上定义唯一性约束。当数据类型为TIMESTAMP WITH LOCAL TIME ZONE
A composite unique key cannot have more than 32 columns.
组合字段定义的唯一索引,字段个数不能超过32个
You cannot designate the same column or combination of columns as both a primary key and a unique key.
你不能指定同一字段或组合字段即为主键又是唯一键
You cannot specify a
unique key when creating a subview in an inheritance hierarchy. The
unique key can be specified only for the top-level (root) view.
约束管理
删除约束
ALTER TABLE DM.EMP
DROP CONSTRAINT SYS_C00115525;
drop table mydept cascade constraints; CASCADE子句用来删除存在有完整性关系的约束。当然你也可以用如下语法 ALTER TABLE DM.EMP
DROP UNIQUE (COMM);
添加约束
添加非空约束 ALTER TABLE DM.EMP
MODIFY(MGR CONSTRAINT CK_EMP_MGR NOT NULL); 添加其他约束 ALTER TABLE DM.EMP
ADD CONSTRAINT CK_EMP_SAL CHECK(SAL > 0 AND SAL <20000);
重命名约束
ALTER TABLE METAONE.T1
RENAME CONSTRAINT SYS_C0059699 TO PK_T1
约束维护
禁用约束
ALTER TABLE 表 DISABLE CONSTRAINT 约束名 [CASCADE];
ALTER TABLE DM.EMP
DISABLE CONSTRAINT UK_EMP_COMM; ALTER TABLE TEST DISABLE PRIMARY KEY CASCADE;
参数CASCADE子句用来关闭存在有完整性关系的约束,比如DISABLE一个主键,如果没有CASCADE子句就会出错,此时使用CASCADE子句DISABLE主键可以将该主键与相关外键一起DISABLE掉。使用的情况:例如在数据库系统中大规模装入数据时,为了系统的效率您不得不牺牲数据的一致性来关闭一些约束,甚至删除一些约束将主表主键禁止的同时,也将禁止依赖于此主键的外键禁止了.
使用上面脚本禁用约束的时候会删除索引,如果你想禁用约束的时候,保留索引,可以使用如下脚本(当然你再启用约束的时候会重新重建索引,这对大表显然开销相当大)
ALTER TABLE DM.EMP
DISABLE CONSTRAINT UK_EMP_COMM KEEP INDEX;
启用约束
如果关闭主键约束时使用了CASCADE,此时使用ENABLE不会将主键约束与外键约束同时打开,只能对主键约束与外键约束分别使用ENABLE CONSTRAINT 子句打开。
推迟约束
Deferring Constraint Checks
当前事务的Constraint Checks全部推迟
SET CONSTRAINTS ALL DEFERRED;
SET CONSTRAINT XXX DEFERRED;
当前会话的Constraint Checks.
ALTER SSSSION SET CONSTRAINTS ALL deferred;
ALTER SSSSION SET CONSTRAINT xxx deferred;
约束信息
SELECT * FROM DBA_CONSTRAINTS; SELECT * FROM ALL_CONSTRAINTS; SELECT * FROM USER_CONSTRAINTS; SELECT * FROM DBA_CONS_COLUMNS; SELECT * FROM ALL_CONS_COLUMNS; SELECT * FROM USER_CONS_COLUMNS;
约束有四种状态:ENABLE、VALID、INVALID、DISABLE
约束的检查机制
IMMEDIATE语句级:Oracle performs its constraint checking after the statement has been completely executed.
DEFERRED(事务级):A constraint is deferred if the system checks that it is satisfied only on commit. If a deferred constraint is violated, then commit causes the transaction to rollback;(推迟到事务提交时才检查约束,谨慎使用)
使用约束建议
关于约束的使用建议,网上有这么一些建议,我觉得挺有用的。大家可以参考一下
1、如果在Oracle提供的几种约束和自定义的程序(触发器、过程或函数)两者之间有选择化,应尽可能使用Oracle的约束;
2、应该在创建表的时候就定义好所需的各种Oracle约束。如果没有的话,应尽可能早地加上所需要的Oracle约束,这样会使系统更可靠,更容易维护;(这个视具体情况而言)
3、Oracle系统进行过多的约束检查会大大的降低Oracle数据库系统的效率;
原文连接:Oracle约束总结
【Oracle】Oracle约束的总结的更多相关文章
- oracle的约束隐式创建索引和先索引后约束的区别
oracle的约束隐式创建索引和先索引后约束的区别 两种情况:1.对于创建约束时隐式创建的索引,在做删除操作的时候: 9i~11g都会连带删除该索引 2.对于先创建索引,再创建约束(使用到此索引)这种 ...
- ORACLE| ORACLE基础语法汇总
创 ORACLE| ORACLE基础语法汇总 2018-07-18 16:47:34 YvesHe 阅读数 9141更多 分类专栏: [数据库] 版权声明:本文为博主原创文章,遵循CC 4.0 B ...
- install_driver(Oracle) failed: Can't load `.../DBD/Oracle/Oracle.so' for module DBD::Oracle
Description This section is from the "Practical mod_perl " book, by Stas Bekman and Eric C ...
- 性能监控工具的配置及使用 - Spotlight On Oracle(oracle)
一. Spotlight On Oracle(oracle)1.1. 工具简介Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现.S ...
- 性能监控工具的配置及使用 - Spotlight On Oracle(oracle) 转:紫漪
一. Spotlight On Oracle(oracle) 1.1. 工具简介 Spotlight是一个强有力的Oracle数据库实时性能诊断工具,提供了一个直观的.可视化的数据库活动展现 ...
- Oracle 唯一 约束(unique constraint) 与 索引(index) 关系说明
一. 官网对Unique Constraints说明 http://download.oracle.com/docs/cd/E11882_01/server.112/e16508/datainte.h ...
- oracle修改约束列
Oracle 增加修改删除字段 添加字段的语法:alter table tablename add (column datatype [default value][null/not null],-. ...
- Oracle之约束
数据的完整性用于确保数据库数据遵从一定的商业的逻辑规则.在oracle中,数据完整性可以使用约束.触发器.应用程序(过程.函数)三种方法来实现,在这三种方法中,因为约束易于维护,并且具有最好的性能,所 ...
- oracle之约束-主键、非空、唯一、check、外键、默认
--首先添加主键约束alter table studentadd constraint PK_student_sno primary key(sno) --删除约束alter table studen ...
- Oracle 检查约束check
--检查约束 create table test1( id ) primary key, email ) check (email like '%@%') ) drop table test1 ,'1 ...
随机推荐
- PHP开发框架比较
PHP开发框架比较 Laravel 是一个简单优雅的 PHP WEB 开发框架,将你从意大利面条式的代码中解放出来.通过简单.优雅.表达式语法开发出很棒的 WEB应用!但是通过使用我们发现Larave ...
- 35个让人惊讶的CSS3动画效果
1. Pure CSS Coke Can 2. Colorful Clock 3. jQuery DJ Hero 4. Animated Pricing Column 5. Slick jQuery ...
- C#.NET常见问题(FAQ)-如何让文本框textbox内容限制为数字
//限制文本框的输入 private void txtQuestionScore_KeyPress(object sender, KeyPressEventArgs e) { if (e.KeyCha ...
- c数据库读写分离和负载均衡策略
最近在学习数据库的读写分离和主从复制,采用的是一主多从策略,采用轮询的方式,读取从数据库的内容.但是,假如某一台从数据库宕机了,而客户端不知道,每次轮选到此从数据库,不都要报错?到网上查阅了资料,找到 ...
- HDS Truecopy实现原理及项目的选择-诸多案例
copy from:http://www.eygle.com/archives/2009/05/hds_truecopy_dataguard.html 诸多案例:http://wenku.baidu. ...
- JAVA WEB 解决编码问题的filter
最近使用Springmvc,GET传输参数的时候,经常出错误,下面介绍添加一个Filter的方法,可以解决这个问题.既支持POST方式也支持GET方式. 首先写一个Filter package com ...
- SQL Server时间戳
select replace(replace(replace(replace(convert(varchar ,getdate() ,126) ,'-' ,'') ,' ' ,'') ,':' ,'' ...
- 架构师速成7.3-devops为什么非常重要
evops是一个非常高大上的名字,事实上说的简单点就是开发和运维本身就是一个团队的,要干就一起把事情干好.谁出了问题,站点都不行. 作为一个架构师.必需要devops,并且要知道怎样推行devops. ...
- 算法笔记_199:第二届蓝桥杯软件类决赛真题(C语言本科)
前言:以下代码部分仅供参考,C语言解答部分全部来自网友,Java语言部分部分参考自网友,对于答案的正确性不能完全保证. 试题1 数论中有著名的四方定理:所有自然数至多只要用四个数的平方和就可以表示. ...
- SpringMVC+Spring+mybatis项目从零开始--Spring mybatis mysql配置实现
上一章我们把SSM项目结构已搭建(SSM框架web项目从零开始--分布式项目结构搭建)完毕,本章将实现Spring,mybatis,mysql等相关配置. 1. 外部架包依赖引入 外部依赖包引入 ...