对于数据库系统来说拥有一套执行基本商业规则的方法是非常重要的如果一个事物元试图插入更新或者删除一个表格行那么它就违反了商业规则然后数据库必须拒绝这个事物元并在应用程序中做错误的标记虽然通过程序代码来规范规则是可行的但是如果有一个更加简单的方法来执行那是最合人意了因为表格可以通过SOL*PLUS和其他有效的方法来访问所以数据库水平可以通过提供更好的解决方案来约束 Oracle提供了大量的约束完整性和数据库的触发器来帮助商业规则的管理让我们暂时先来探索一些约束完整性然后再将焦点放到外码的约束上这个将是我们这篇文章的主要内容 参照完整性(RI)的规则确定了一对多和多对多的关系强迫在关系计划中另外有效值同样也被约束强迫对于Web服务器应用程序来说约束特别重要因为Web服务器允许约束在数据库服务器中检查发生因此它担当了校对约束的任务 在Oracle表格中可以应用几种类型的约束来规范数据的完整性它包括 ·检查约束在行插入时间的时候这个约束被有效的引入到列中在检验region所有出现的地方时需要使用一个应用程序来检查是东南西或者北现在将检查约束加入到表格说来定义确保region栏的有效性 ·非空约束这个约束被用作说明一个列中不包含一个空值在SQL insert和update时间中这个是被强迫加入的 ·主码约束这个约束是用来确定表格的主码这个操作需要原来的列是唯一的并且Oracle将在目标主码上创建一个唯一的索引 ·参考约束这是外键约束由Oracle来完成一个参考约束仅仅应用在SQL 的插入和删除时间里比如一个一对多的关系存在于EMPLOYEE和DEPENDENT表格中每个职工可能有许多相依赖的关系但是每个关系仅仅属于一个职工这个参考约束在insert时间告诉Oracle在DEPENDENTemp_num中的值必须和职员栏中的EMPLOYEEemp_num相匹配因此在关系栏添加之前一定要确保有效职员存在如果这个行依旧存在于DEPENDENT表格中那么在SQL delete时间里参照约束可以用来确定职员不被删除 ·唯一约束这个约束确保表格中所有列的值不会出现在复写条目中 注意唯一和主键的区别它们都是创建一个唯一的索引一个表格仅含有一个主键约束列但是它有可能在其他列中含有许多的唯一约束 外键约束 参照完整性外键约束确定了表格或者视图的栏作为外键这个外键栏和一个主键或者唯一键在另外一个表格中建立了直接的关系这个表格包含的外键被引用做孩子并且参考键被用做双亲表格外键和参考键可以被用在同一个表格中除此之外双亲和子表必须在相同的数据库中 下面是创建一个外键约束的语法 ALTER TABLE (table_name) ADD CONSTRAINT (foreign key constraint name) FOREIGN KEY ( field name ) REFERENCES primary_table_name (primary_table_primary_index_field) 虽然外键约束通常被用在应用程序编码的场所来进行完整性的检查但是使用参考完整性的约束加入到I/O开销中来执行insert和update操作是重要的另外的I/O是可归于外键必须使双亲表有效的事实通过保证参考列表被检索可使这个开销最小在大量的重载中它在使先前的完整约束丧失能力重载和在重载完成后使约束恢复能力的过程中非常有用一旦约束被激活任何错误都可被纪录和操作 参照完整性有时候需要双重编码比如在多重SQL*Form中你也许不知道参照完整性是否违反了规则直到你将许多页面放到表格中并且你的表格试图提交的事物元的时候在Web服务器应用程序中你需要非常小心的保证Oracle事物元的安全 参照完整性 一个数据库系统要有能力执行商业规则参照完整性是Oracle提供给商业规则的一个方法有关系统允许商业规则利用约束来控制并参照完整性成了关联表格的骨干 许多应用程序不使用外键参考完整性它们利用应用程序代码来执行商业规则这个方法并不简单因为应用表格可以通过其他的方法比如SQL*PLUS被访问 |