SQL建表教程:从基础到完整性约束

需积分: 3 1 下载量 179 浏览量 更新于2024-09-12 收藏 36KB DOC 举报
"该文档是关于SQL建表的教程,包含基本表的创建语句以及如何定义完整性约束,适用于SQL初学者。" 在SQL中,建表是数据库管理的基础操作,用于创建数据存储的结构。以下是对标题和描述中涉及的知识点的详细解释: 1. **基本表语句语法**: SQL中的`CREATE TABLE`语句用于创建新的表。基本语法如下: ``` USE 数据库名; CREATE TABLE 表名 ( 列名 数据类型(大小) DEFAULT '默认值', 列名 数据类型(大小) DEFAULT '默认值', 列名 数据类型(大小) DEFAULT '默认值', ... ); ``` 这里,`USE 数据库名`用于切换到特定的数据库,`CREATE TABLE`后跟着表的名称,然后列出各个列的定义,包括列名、数据类型和可选的默认值。例如,创建一个包含五列的表`S`,其中第四列的默认值为'男': ``` CREATE TABLE S ( SNO char(2), SNAME char(8), AGE decimal(2), SEX char(2) DEFAULT '男', DEPT char(2) ); ``` 2. **定义完整性约束**: 完整性约束确保数据的准确性和一致性。SQL提供了多种类型的约束,如非空约束、唯一约束等。定义完整性约束的基本语法如下: ``` USE 数据库名; CREATE TABLE 表名 ( 列名 数据类型(大小) DEFAULT '默认值' CONSTRAINT 约束名 约束定义, 列名 数据类型(大小) DEFAULT '默认值' CONSTRAINT 约束名 约束定义, 列名 数据类型(大小) DEFAULT '默认值' CONSTRAINT 约束名 约束定义, ... ); ``` - **非空约束 (NULL | NOT NULL)**: `NOT NULL`约束确保列的值不能为空。例如,创建`Persons`表,强制`Id_P`和`LastName`列不允许为空: ``` CREATE TABLE Persons ( Id_P int NOT NULL, LastName varchar(255) NOT NULL, FirstName varchar(255), Address varchar(255), City varchar(255) ); ``` - `NOT NULL`约束强制字段在插入或更新时必须提供值,否则操作会失败。 - **唯一约束 (UNIQUE)**: `UNIQUE`约束确保表中某列或列的组合的值都是唯一的。这可以创建一个隐式或显式的唯一索引。例如,如果希望`Email`列在表中是唯一的,可以这样定义: ``` CREATE TABLE Users ( UserId int PRIMARY KEY, Email varchar(255) UNIQUE ); ``` 或者,如果希望`PhoneNumber`和`City`的组合在表中是唯一的: ``` CREATE TABLE Contacts ( ContactId int PRIMARY KEY, PhoneNumber varchar(20), City varchar(50), CONSTRAINT Unique_ContactInfo UNIQUE (PhoneNumber, City) ); ``` 总结来说,SQL建表涉及到的关键知识点包括`CREATE TABLE`语句的使用,以及如何定义列的数据类型、默认值以及各种完整性约束,如非空约束和唯一约束,这些都是构建高效、安全数据库系统的基础。通过熟练掌握这些概念,可以有效地管理和维护数据库中的数据。