SQL约束详解:主键、唯一性与外键
需积分: 9 24 浏览量
更新于2024-08-15
收藏 6.86MB PPT 举报
"本章小结涵盖了SQL中的约束问题,主要讲解了如何创建和管理数据库以及数据表,并强调了在SQLServer2000中使用约束来维护数据库完整性的重要性。内容涉及了五种主要的约束类型:主键约束、唯一性约束、外键约束、核查约束和缺省约束。此外,还提供了设置主键约束和唯一性约束的示例。"
在SQL中,约束是确保数据完整性和一致性的关键机制。以下是关于SQL约束的详细说明:
1. 主键约束(Primary Key Constraint):主键是表中的一个或多个字段,用于唯一标识表中的每一行。它不允许有重复值,并且不能为空。创建主键约束可以使用`CREATE TABLE`语句中的`CONSTRAINT`关键字,或者通过`ALTER TABLE`语句后来添加。例如,创建一个名为`XS`的表,其中`学号`字段作为主键:
```sql
CREATE TABLE XS (
学号 CHAR(6) CONSTRAINT pk_pnum PRIMARY KEY,
姓名 CHAR(8)
);
```
2. 唯一性约束(Unique Constraint):与主键类似,唯一性约束确保列中的所有值都是唯一的,但不一定要作为标识符。可以应用于任何列,甚至允许有NULL值。创建唯一性约束的语法与主键相似,只是不使用`PRIMARY KEY`关键字。
3. 外键约束(Foreign Key Constraint):外键约束定义了两个表之间的关系,其中一个表(子表)的字段引用另一个表(父表)的主键。这确保了参照完整性和数据一致性。例如,如果有一个`成绩`表引用`学生`表的`学号`,则可以通过以下方式添加外键约束:
```sql
ALTER TABLE 成绩
ADD CONSTRAINT fk_score_pnum FOREIGN KEY (学号) REFERENCES XS (学号);
```
4. 核查约束(Check Constraint):核查约束允许开发者指定列中的值必须满足的特定条件。例如,如果一个列表示年龄,可以设定其值必须在0到150之间:
```sql
CREATE TABLE 人员 (
年龄 INT CHECK (年龄 BETWEEN 0 AND 150)
);
```
5. 缺省约束(Default Constraint):当插入新记录时,如果未提供某列的值,系统会自动使用缺省值。例如,为`创建日期`字段设置当前日期作为默认值:
```sql
CREATE TABLE 订单 (
订单ID INT PRIMARY KEY,
下单日期 DATE DEFAULT GETDATE()
);
```
这些约束在SQLServer2000中是至关重要的,因为它们帮助确保数据的准确性和一致性,防止不合法的数据进入数据库。了解和正确使用这些约束是设计和管理高效、可靠的数据库系统的基础。
2009-11-11 上传
1230 浏览量
2011-08-29 上传
2020-09-11 上传
2020-12-15 上传
2020-12-16 上传
2020-09-11 上传
2011-12-30 上传
2020-09-11 上传
鲁严波
- 粉丝: 25
- 资源: 2万+
最新资源
- JHU荣誉单变量微积分课程教案介绍
- Naruto爱好者必备CLI测试应用
- Android应用显示Ignaz-Taschner-Gymnasium取消课程概览
- ASP学生信息档案管理系统毕业设计及完整源码
- Java商城源码解析:酒店管理系统快速开发指南
- 构建可解析文本框:.NET 3.5中实现文本解析与验证
- Java语言打造任天堂红白机模拟器—nes4j解析
- 基于Hadoop和Hive的网络流量分析工具介绍
- Unity实现帝国象棋:从游戏到复刻
- WordPress文档嵌入插件:无需浏览器插件即可上传和显示文档
- Android开源项目精选:优秀项目篇
- 黑色设计商务酷站模板 - 网站构建新选择
- Rollup插件去除JS文件横幅:横扫许可证头
- AngularDart中Hammock服务的使用与REST API集成
- 开源AVR编程器:高效、低成本的微控制器编程解决方案
- Anya Keller 图片组合的开发部署记录