数据库完整性:实体与参照完整性详解

需积分: 31 1 下载量 28 浏览量 更新于2024-08-15 收藏 448KB PPT 举报
"数据库完整性是确保数据库中数据的正确性和相容性的机制,分为实体完整性、参照完整性和用户定义的完整性。实体完整性规定了主键属性不允许为空,可以通过在CREATE TABLE语句中定义主键来实现。参照完整性则涉及到表之间的关联,确保引用的外键存在于被引用的主键中,防止出现无效引用。用户定义的完整性允许用户自定义特定的约束条件。此外,完整性约束还可以通过触发器来实现,以在数据修改时自动执行检查和处理。完整性检查和违约处理是DBMS的重要功能,旨在防止非法或不正确的数据进入数据库。" 在数据库系统中,数据库完整性是确保数据准确无误和符合语义的关键方面。它与数据安全性不同,后者关注的是防止恶意破坏和非法访问。数据库完整性分为三个主要部分: 1. **实体完整性**:这是最基本的一种完整性,它要求表中的每个记录都有一个唯一的标识,通常由主键定义。在创建表时,可以使用PRIMARY KEY约束来指定主键,对于单属性主键,可以在列级或表级定义;对于多属性主键,只能在表级定义。例如,Student表中的Sno作为主键,可以这样定义: ```sql CREATE TABLE Student ( Sno CHAR(9) PRIMARY KEY, Sname CHAR(20) NOT NULL, Ssex CHAR(2), Sage SMALLINT, Sdept CHAR(20) ); ``` 2. **参照完整性**:此完整性确保了表之间的关联,即外键字段的值必须是参照表主键字段的有效值。在SC表的创建中,Sno和Cno作为外键,参照Student和Course表的主键: ```sql CREATE TABLE SC ( Sno CHAR(9) NOT NULL, Cno CHAR(4) NOT NULL, Grade SMALLINT, PRIMARY KEY (Sno, Cno), FOREIGN KEY (Sno) REFERENCES Student(Sno), FOREIGN KEY (Cno) REFERENCES Course(Cno) ); ``` 这样就确保了SC表中的Sno和Cno值在Student和Course表中都是存在的。 3. **用户定义的完整性**:用户可以根据业务需求定义自己的完整性约束,这可以是任何复杂的逻辑条件,通过添加CHECK约束来实现。例如,可以限制学生的年龄范围: ```sql ALTER TABLE Student ADD CONSTRAINT AgeCheck CHECK (Sage BETWEEN 15 AND 40); ``` 除了这些,DBMS还提供了完整性约束命名、域中的完整性限制(如数据类型限制)、触发器等工具来进一步增强数据的完整性。触发器是一种预定义的程序,当满足特定条件时自动执行,可以用来在数据更新时即时检查和处理完整性约束。 总结来说,数据库完整性是数据库管理系统的重要组成部分,通过各种约束和机制确保数据的准确性和一致性,防止错误数据的存储,从而保证数据的质量和系统的稳定性。