SQLServer2000约束详解:主键、唯一性与外键

5星 · 超过95%的资源 需积分: 15 4 下载量 129 浏览量 更新于2024-07-29 1 收藏 6.86MB PPT 举报
"SQL约束是SQLServer用于维护数据库完整性的重要机制,包括主键约束、唯一性约束、外键约束、核查约束、Null约束和default约束以及规则和默认值。这些约束确保了数据的一致性和准确性。以下是各约束的详细解释: 1. **主键约束 (Primary Key Constraint)**: 主键是表中的一个或多个字段,它们的值在全表中必须唯一,并且不允许有NULL值。主键用于唯一标识每条记录。创建主键约束可以使用`CREATE TABLE`语句或`ALTER TABLE`语句添加,例如在表XS中设置学号为主键约束: ```sql CREATE TABLE XS ( 学号 char(6) CONSTRAINT pk_pnum PRIMARY KEY, 姓名 char(8) ); ``` 或者,如果需要两个字段作为联合主键: ```sql CREATE TABLE XS ( 学号 char(6), 姓名 char(8), CONSTRAINT pk_pnum_pnam PRIMARY KEY (学号, 姓名) ); ``` 2. **唯一性约束 (Unique Constraint)**: 唯一性约束要求指定列的值必须是唯一的,但允许NULL值。这与主键约束类似,但不强制作为标识符。例如,创建一个唯一性约束可以这样写: ```sql ALTER TABLE XS ADD CONSTRAINT uc_pnum UNIQUE (学号); ``` 3. **外键约束 (Foreign Key Constraint)**: 外键约束用于建立两个表之间的关联,确保引用完整性。外键列的值必须存在于被引用表的主键或唯一键列中。例如,如果表KS有外键指向XS的学号: ```sql CREATE TABLE KS ( 科目 char(10), 学号 char(6) REFERENCES XS (学号) ); ``` 4. **核查约束 (Check Constraint)**: 核查约束允许对列的值设置特定条件,确保输入的数据符合预设规则。例如,确保年龄在18到60之间: ```sql ALTER TABLE XS ADD CONSTRAINT chk_age CHECK (年龄 BETWEEN 18 AND 60); ``` 5. **Null约束和Default约束**: NULL约束不允许列包含NULL值,而Default约束为列提供默认值。如果学号默认为空字符串: ```sql ALTER TABLE XS MODIFY COLUMN 学号 char(6) NOT NULL DEFAULT ''; ``` 6. **规则 (Rule)**: 规则类似于核查约束,用于定义列值的格式或限制,但在SQL Server中,规则已不推荐使用,而是建议使用CHECK约束。 7. **默认值 (Default Value)**: 默认值允许在未指定值时为列提供一个预设值。例如,如果姓名默认为'未知': ```sql ALTER TABLE XS MODIFY COLUMN 姓名 char(8) DEFAULT '未知'; ``` 通过正确使用这些约束,可以确保在SQLServer2000中创建的数据库具有高度的数据完整性,从而支持高效、可靠的数据库操作。"