Welcome 微信登录

首页 / 数据库 / MySQL / Oracle完整性约束

完整性约束 完整性约束用于增强数据的完整性,Oracle提供了5种完整性约束: Check NOT NULL Unique Primary Foreign key 完整性约束是一种规则,不占用任何数据库空间。完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户可以指明约束是启用的还是禁用的,当约束启用时,他增强了数据的完整性,否则,则反之,但约束始终存在于数据字典中。 禁用约束,使用ALTER语句ALTER TABLE table_name DISABLE CONSTRAINT constraint_name; 或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 约束 在数据列上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)。
 
删除或禁用唯一性约束通常同时删除相关联的唯一索引,因而降低了数据库性能。经常删除或禁用唯一性约束有可能导致丢失索引带来的性能错误。要避免这样错误,可以采取下面的步骤:
 
1、在唯一性约束保护的数据列上创建非唯一性索引。
 
2、添加唯一性约束
 
主键(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;
  • 1
  • 2
  • 下一页
Oracle 10g ORA-00257解决一例Oracle收集用户的权限相关资讯      Oracle约束  完整性约束 
  • Oracle约束的分类  (03/17/2015 19:28:41)
  • Oracle约束Constraint对于CBO优化  (05/05/2014 19:49:38)
  • Oracle数据完整性约束:主键、外键  (10/27/2013 16:56:40)
  • Oracle外键约束(Foreign Key)的  (12/06/2014 14:41:09)
  • Oracle数据库中由于没有做任何约束  (04/01/2014 17:27:56)
  • Oracle数据库的字段约束创建和维护  (10/02/2013 19:31:45)
本文评论 查看全部评论 (0)
表情: 姓名: 字数