`
Phil_Xzh
  • 浏览: 19469 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类

Oracle完整性约束

阅读更多
  完整性约束用于增强数据的完整性,Oracle提供了5种完整性约束:
  • Check
  • NOT NULL
  • Unique
  • Primary
  • Foreign key
  完整性约束是一种规则,不占用任何数据库空间。完整性约束存在数据字典中,在执行SQL或PL/SQL期间使用。用户可以指明约束是启用的还是禁用的,当约束启用时,他增强了数据的完整性,否则,则反之,但约束始终存在于数据字典中。
1) 禁用约束
ALTER TABLE table_name DISABLE CONSTRAINT constraint_name;

2) 重新启用约束
ALTER TABLE table_name ENABLE CONSTRAINT chk_gender;

3) 删除约束
ALTER TABLE table_name DROP CONSTRAINT constraint_name;


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.   
  3. 添加唯一性约束。


主键(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 --; 

  序列(Sequences)
  Oracle序列是一个连续的数字生成器。序列常用于人为的关键字,或给数据行排序否则数据行是无序的。像约束一样,序列只存在于数据字典中。序列号可以被设置为上升、下降,可以没有限制或重复使用直到一个限制值。创建序列使用SET SEQUENCE语句。
CREATE SEQUENCE [schema] sequence KEYWORD

  KEYWORD包括下面的值:
  • KEYWORD 描述
  • START WITH 定义序列生成的第一个数字,缺省为1
  • INCREMENT BY 定义序列号是上升还是下降,对于一个降序的序列INCREMENT BY为负值
  • MINVALUE 定义序列可以生成的最小值,这是降序序列中的限制值。缺省情况下该值为NOMINVALUE,NOMINVALUE,对于升序为1,对于降序为-10E26.
  • MAXVALUE 序列能生成的最大数字。这是升序序列中的限制值,缺省的MAXVALUE为NOMAXVALUE,NOMAXVALUE,对于升序为10E26,对于降序为-1。
  • CYCLE 设置序列值在达到限制值以后可以重复
  • NOCYCLE 设置序列值在达到限制值以后不能重复,这是缺省设置。当试图产生MAXVALUE+1的值时,将会产生一个异常
  • CACHE 定义序列值占据的内存榈拇笮。 笔≈滴?0
  • NOCACHE 在每次序列号产生时强制数据字典更新,保证在序列值之间没有间隔当创建序列时,START WITH值必须等于或大于MINVALUE。

  删除序列使用DROP SEQUENCE语句
DROP SEQUENCE sequence_name 


分享到:
评论

相关推荐

    Oracle数据库的完整性约束规则详解

    Oracle数据库的完整性约束规则详解.DOC

    Oracle数据完整性约束机制

    关于Oracle数据库的数据完整性约束的类型和实现

    ORACLE数据库完整性约束浅析.pdf

    ORACLE数据库完整性约束浅析.pdf

    基于Oracle的数据库完整性约束分析.pdf

    基于Oracle的数据库完整性约束分析.pdf

    基于Oracle数据库的完整性约束应用研究.pdf

    基于Oracle数据库的完整性约束应用研究.pdf

    Oracle数据库的完整性约束和序列规则详解

    Oracle数据库的完整性约束和序列规则详解,初学者非常不错的手册

    Oracle数据库的完整性约束和序列规则详解[收集].pdf

    Oracle数据库的完整性约束和序列规则详解[收集].pdf

    表空间-用户模式及完整性约束

    Oracle实验表空间及完整性约束,包含详细代码

    数据库5关系数据库完整性实验.doc

    实验内容与步骤 ORACLE环境中通过触发器可以定义为更复杂的完整性约束 例1:通过触发器产生主键值 create sequence ql minvalue 010341416; create table student(sno number(9) primary key ,sname varchar2(20));...

    违反完整性约束 未找到父项关键字

    当向有外键关联的表中添加数据时可能就会出现违反完整约束、未找到父项关键字,查看外键关联的表时发现你要使用的数据是存在的,原因就是数据库存在的数据有问题,本人提供的方法的是查询出有问题的数据,希望可以帮...

    Oracle触发器实验报告

    表employees和department存在参照完整性约束,在表employees中插入记录(‘70’,‘999’)department_id为‘999’时,department表中还不存在department_id为‘999’的记录,所以违背了参照完整性约束,出现...

    21天学会oracle

    21天学会oracle(电子教案)...第18章 数据库速度优化与数据完整性.ppt 第19章 数据一致性与事务管理.ppt 第20章 并发控制.ppt 第21章 Oracle中的正则表达式.ppt 第22章 Oracle在Java开发中的.ppt 第23章 Oracle在C.ppt

    21天学通Oracle

    第18章 数据库速度优化与数据完整性(教学视频:32分钟) 332 第19章 数据一致性与事务管理(教学视频:46分钟) 341 第20章 并发控制(教学视频:35分钟) 356 第21章 Oracle中的正则表达式(教学视频:29分钟)...

    Oracle11g从入门到精通2

    1.2.6 数据完整性约束 1.2.7 联机事务处理和联机分析处理 1.2.8 数据仓库 1.3 Oracle基本术语 1.3.1 数据字典 1.3.2 数据文件 1.3.3 控制文件 1.3.4 日志文件 1.3.5 表空间 1.3.6 段 1.3.7 区 ...

    oracle全程笔记及代码

    完整性约束是指数据的正确性与完备性。 1)表:具有行列结构,每一行成为记录,每一列成为字段,字段都是有类型的。 2)数据操作:数据的创建数据的修改数据的删除数据的查询等,这些基本的操作被称为SQL...

    Oracle 10g应用指导

    完整性约束的管理;索引,包括B树索引、基于函数的索引、位图索引、反向索引、降序索引、压缩索引等的使用方法及其适用情形等。在案例精讲中,对表压缩、约束的使能与失能、表的层次结构查询、防止删除表及对象、...

    oracle10g课堂练习I(1)

    了解数据完整性 7-13 定义约束条件 7-15 违反约束条件 7-16 约束条件状态 7-17 约束条件检查 7-19 使用 SQL 创建约束条件:示例 7-20 查看表中的列 7-21 查看表的内容 7-22 对表执行的操作 7-23 删除表 7-...

    Oracle 常用系统表

    完整性约束 DBA_CONSTRAINTS、ALL_CONSTRAINTS和USER_CONSTRAINST显示有关约束的一般信息。 DBA_CONS_COLUMNS、ALL_CONS_COLUMNS和USER_CONS_COLUMNS显示有关列的相关约束的一般信息。 视图 DBA_VIEWS、ALL_...

    oracle数据库入门命令

    oracle数据库入门命令 1. SQL语言:关系数据库的标准语言 2. PL/SQL:过程化语言Procedural Language 3. SQL*Plus:简单的报表,操作系统接口 (1) 数据分区技术:只...(4) 数据完整性约束(Data Integrity Constraints)

Global site tag (gtag.js) - Google Analytics