SQL进阶五:SQL完整性约束

完整性约束用于加强数据的完整性,Oracle提供了5种完整性约束:    数据库

            Check
NOT NULL
Unique
Primary
Foreign keyoracle

  完整性约束是一种规则,不占用任何数据库空间。完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户能够指明约束是启用的仍是禁用的,当约束启用时,他加强了数据的完整性,不然,则反之,但约束始终存在于数据字典中。ide

  禁用约束,使用ALTER语句函数

ALTER TABLE table_name DISABLE CONSTRAINT constraint_name;
性能


spa

ALTER TABLE policies DISABLE CONSTRAINT chk_gender

若是要从新启用约束:对象

ALTER TABLE policies ENABLE CONSTRAINT chk_gender

删除约束索引

ALTER TABLE table_name DROP CONSTRAINT constraint_name

事务

ALTER TABLE policies DROP CONSTRAINT chk_gender;

Check 约束ci

  在数据列上Check 约束须要  一个特殊的布尔条件或者将数据列设置成TRUE,至少一个数据列的值是NULL,Check约束用于加强表中数据内容的简单的商业规则。用户使用Check约束保证数据规则的一致性check约束能够涉及该行同属Check约束的其余数据列但不能涉及其余行或其余表,或调用函数SYSDATE,UID,USER,USERENV。若是用户的商业规则须要这类的数据检查,那么可使用触发器。Check约束不保护LOB数据类型的数据列和对象、嵌套表、VARRY、ref等。单一数据列能够有多个Check约束保护,一个Check约束能够保护多个数据列。

  建立表的Check约束使用CREATE TABLE语句,更改表的约束使用ALTER TABLE语句。

  语法:

CONSTRAINT [constraint_name] CHECK  (condition);

Check约束能够被建立或增长为一个表约束,当Check约束保护多个数据列时,必须使用表约束语法。约束名是可选的而且若是这个名字不存在,那么oracle将产生一个以SYS_开始的惟一的名字。

  例:

CREATE TABLE policies
(policy_id NUMBER,
holder_name  VARCHAR2(40),
gender VARCHAR2(1) constraint chk_gender CHECK (gender in  ('M','F'),
marital_status VARCHAR2(1),
date_of_birth DATE,
constraint  chk_marital CHECK (marital_status in('S','M','D','W'))
);

NOT  NULL约束

  NOT  NULL约束应用在单一的数据列上,而且他保护的数据列必需要有数据值。缺省情况下,ORACLE容许任何列均可以有NULL值。某些商业规则要求某数据列必需要有值,NOT  NULL约束将确保该列的全部数据行都有值。

  例:

CREATE TABLE policies
(policy_id NUMBER,
holder_name VARCHAR2(40) NOT  NULL,
gender VARCHAR2(1),
marital_status VARCHAR2(1),
date_of_birth  DATE NOT NULL
);

对于NOT NULL的ALTER TABLE语句与其余约束稍微有点不一样。

ALTER TABLE policies MODIFY holder_name NOT NULL
 惟一性约束(Unique  constraint)

  惟一性约束能够保护表中多个数据列,保证在保护的数据列中任何两行的数据都不相同。惟一性约束与表一块儿建立,在惟一性约束建立后,可使用ALTER  TABLE语句修改。

  语法:

column_name data_type CONSTRAINT constraint_name  UNIQUE

若是惟一性约束保护多个数据列,那么惟一性约束要做为表约束增长。语法以下:

CONSTRAINT constraint_name (column) UNIQUE USING INDEX TABLESPACE  (tablespace_name) STORAGE (stored clause)


惟一性约束由一个B-tree索引加强,因此能够在USING子串中为索引使用特殊特征,好比表空间或存储参数。CREATE  TABLE语句在建立惟一性约束的同时也给目标数据列创建了一个惟一的索引。

CREATE TABLE insured_autos
(policy_id NUMBER CONSTRAINT pk_policies  PRIMARY KEY,
vin VARCHAR2(10),
coverage_begin DATE,
coverage_term  NUMBER,
CONSTRAIN unique_auto UNIQUE (policy_id,vin) USING INDEX TABLESPACE  index STORAGE (INITIAL 1M NEXT 10M PCTINCREASE 0)
);


用户能够禁用未以性约束,但他仍然存在,禁用惟一性约束使用ALTER TABLE 语句

ALTER TABLE insured_autos DISABLE CONSTRAIN unique_name;


删除惟一性约束,使用ALTER TABLE....DROP CONSTRAIN语句

ALTER TABLE insured_autos DROP CONSTRAIN unique_name;


注意用户不能删除在有外部键指向的表的惟一性约束。这种状况下用户必须首先禁用或删除外部键(foreign key)。

  删除或禁用惟一性约束一般同时删除相关联的惟一索引,于是下降了数据库性能。常常删除或禁用惟一性约束有可能致使丢失索引带来的性能错误。要避免这样错误,能够采起下面的步骤:

  一、在惟一性约束保护的数据列上建立非惟一性索引。

  二、添加惟一性约束

  主键(Primary Key)约束

  表有惟一的主键约束。表的主键能够保护一个或多个列,主键约束可与NOT NULL约束共同做用于每一数据列。NOT  NULL约束和惟一性约束的组合将保证主键惟一地标识每一行。像惟一性约束同样,主键由B-tree索引加强。

  建立主键约束使用CREATE TABLE语句与表一块儿建立,若是表已经建立了,可使用ALTER TABLE语句。

CREATE TABLE policies
(policy_id NUMBER CONSTRAINT pk_policies PRIMARY  KEY,
holder_name VARCHAR2(40),
gender VARCHAR2(1),
marital_status  VARCHAR2(1),
date_of_birth DATE
);


与惟一性约束同样,若是主键约束保护多个数据列,那么必须做为一个表约束建立。

CREATE TABLE insured_autos
(policy_id NUMBER,
vin  VARCHAR2(40),
coverage_begin DATE,
coverage_term NUMBER,
CONSTRAINT  pk_insured_autos PRIMARY KEY (policy_id,vin)
USING INDEX TABLESPACE  index
STORAGE (INITIAL 1M NEXT 10M PCTINCREASE 0)
);


禁用或删除主键必须与ALTER TABLE 语句一块儿使用

ALTER TABLE policies DROP PRIMARY KEY;


ALTER TABLE policies DISABLE PRIMARY KEY;


外部键约束(Foreign key constraint)

  外部键约束保护一个或多个数据列,保证每一个数据行的数据包含一个或多个null值,或者在保护的数据列上同时拥有主键约束或惟一性约束。引用(主键或惟一性约束)约束能够保护同一个表,也能够保护不一样的表。与主键和惟一性约束不一样外部键不会隐式创建一个B-tree索引。在处理外部键时,咱们经常使用术语父表(parent  table)和子表(child table),父表表示被引用主键或惟一性约束的表,子表表示引用主键和惟一性约束的表。

  建立外部键使用CREATE TABLE语句,若是表已经创建了,那么使用ALTER TABLE语句。

CREATE TABLE insured_autos
(policy_id NUMBER CONSTRAINT  policy_fk
REFERENCE policies(policy_id
ON DELETE CASCADE,
vin  VARCHAR2(40),
coverage_begin DATE,
coverage_term NUMBER,
make  VARCHAR2(30),
model VARCHAR(30),
year NUMBER,
CONSTRAIN auto_fk FROEIGN  KEY (make,model,year)
REFERENCES automobiles (make,model,year)
ON DELETE  SET NULL
);


ON DELETE子串告诉ORACLE若是父纪录(parent  record)被删除后,子记录作什么。缺省状况下禁止在子记录还存在的状况下删除父纪录。

  外部键和NULL值

  在外部键约束保护的数据列中NULL值的处理可能产生不可预料的结果。ORACLE 使用ISO standar Match  None规则加强外部键约束。这个规则规定若是任何外部键做用的数据列包含有一个NULL值,那么任何保留该键的数据列在父表中没有匹配值。

  好比,在父表AUTOMOBILES中,主键做用于数据列MAKE,MODEL,YEAR上,用户使用的表INSURED_AUTOS有一个外部约束指向AOTOMOBILES,注意在INSURES_AUTOS中有一数据行的MODEL列为NULL值,这一行数据已经经过约束检查,即便MAKE列也没有显示在父表AUTOMOBILES中,以下表:

  表1 AUTOMOBILES

MAKE
MODEL
YEAR

Ford  
Taurus
2000

Toyota
Camry
1999


表2 INSURED_AUTOS

POLICY_ID
MAKE
MODEL
YEAR

576
Ford
Taurus  
2000

577
Toyota
Camry
1999

578
Tucker  
NULL
1949


延迟约束检验(Deferred Constraint Checking)

  约束检验分两种状况,一种是在每一条语句结束后检验数据是否知足约束条件,这种检验称为当即约束检验(immediately  checking),另外一种是在事务处理完成以后对数据进行检验称之为延迟约束检验。在缺省状况下Oracle约束检验是当即检验(immediately  checking),若是不知足约束将先是一条错误信息,但用户能够经过SET CONSTRAINT语句选择延迟约束检验。语法以下:

SET CONSTRAINT constraint_name|ALL DEFEERRED|IMMEDIATE --;

相关文章
相关标签/搜索