oracle如何实现数据库的完整性

oracle如何实现数据库的完整性,第1张

ORACLE应用于关系数据库的表的数据完整性有下列类型: 在插入或修改表的行时允许不允许包含有空值的列,称为空与非空规则。 唯一列值规则,允许插入或修改的表行在该列上的值唯一。 引用完整性规则,同关系模型定义 用户对定义的规则,为复杂性完整性检查。 ORACLE允许定义和实施上述每一种类型的数据完整性规则,这些规则可用完整性约束和数据库触发器定义。 完整性约束,是对表的列定义一规则的说明性方法。 数据库触发器,是使用非说明方法实施完整性规则,利用数据库触发器(存储的数据库过程)可定义和实施任何类型的完整性规则。

求采纳

关系模型的三类完整性是实体完整性、参照完整性和用户完整性。

实体完整性和参照完整性是关系模型必须满足的完整性约束条件,应由关系系统自动支持。

1、实体完整性

(entity

integity)

实体完整性是基于主码的,一个主码由一个或多个属性组成。实体完整性要求主码中的任一属性(列)不能为空,所谓空值

是“不知道”或“无意义”的值。之所以要保证实体完整性主要是因为:在关系中,每一个元组的区分是依据主码值的不同,若主码值取空值,则不能标明该元组的

存在。

2、参照完整性

(efeential

integity)

参照完整性是基于外码的,若基本关系R中含有与另一基本关系S的主码PK相对应的属性组FK(FK称为R的外码),则参照完整性要求,对R中的每个元组在FK上的值必须是S中某个元组的PK值,或者为空值。

参照完整性的合理性在于:R中的外码只能对S中主码的引用,不能是S中主码没有的值.如学生和选课表两关系,选课表中的学号是外码,它是学生表的主键,若选课表中出现了某个学生表中没有的学号,即某个学生还没有注册,却已有了选课记录,这显然是不合理的。

3、用户定义的完整性(use-defined

integity)

实体完整性和参照完整性适用于任何关系数据库系统。除此之外,不同的关系数据库系统根据其应用环境的不同,往往还需

要一些特殊的约束条件。用户定义的完整性就是针对某一具体关系数据库的约束条件,它反映某一具体应用所涉及的数据必须满足的语义要求。如:学生的成绩一般

情况下的取值范围在0-100之间。

二、Oacle的数据完整性的实现

1、Oacle中的实体完整性

实体完整性规则要求主属性非空。Oacle在CREATE

TABLE语句中提供了PRIMARY

KEY子句,供用户在建表时指定关系的主码列。例如:在学生选课数据库中,要定义Student表的sno属性为主码,可使用如下语句:

SQL

CREATE

TABLE

Student

(

sno

NUMBER

(8),

sname

VARCHAR(20),

sage

NUMBER(20),CONSTRAINT

PK_SNO

PRIMARY

KEY

(sno))

其中:PRIMARY

KEY(SNO)表示SNO是Student表的主码。PK_SNO是此主码约束名。

在用PRIMARY

KEY语句定义了关系的主码后,每当用户程序对主码列进行更新 *** 作时,系统自动进行完整性检查,凡 *** 作使主码值为空值或使主码值在表中不唯一,系统拒绝此 *** 作,从而保证了实体完整性。

2、ORACLE中的参照完整性

Oacle的CREATE

TABLE语句不仅可以定义关系的实体完整性规则,也可以定义参照完整性规则,即用户可以在建表时用FOREIGN

KEY

子句定义哪些列为外码列,用REFERENCES子句指明这些外码相应于哪个表的主码,用ON

DELETE

CASCADE

子句指明在删除被参照关系的元组时,同时删除参照关系中外码值等于被删除的被参照关系的元组中主码值中的元组。

SQL

CREATE

TABLE

SC

(sno

NUMBER

(8)

cno

NUMBER

(2),

g

ade

NUMBER

(3),

CONSTRAINT

PK_SC

PRIMARY

KEY(sno,cno),CONSTRAINT

FK_SNO

FOREIGN

KEY

(sno)

REFERENCES

student(sno)

on

delete

CASCADE)


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/6701384.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-03-27
下一篇2023-03-27

发表评论

登录后才能评论

评论列表(0条)

    保存