# 4.1 创建数据表
## 4.1.1 创建表的语法形式
* 创建数据表的语句为 CREATE TABLE。
~~~
CREATE TABLE <表名>
(
列名1,数据类型 [列级别约束条件] [默认值],
列名2,数据类型 [列级别约束条件] [默认值],
……
[表级别约束条件]
);
~~~
## 4.1.2 使用主键约束
* 主键,又称主码,是表中一列或多列的组合。主键约束(Primary Key constraint)要求主键列的数据唯一,并且不允许为空。
* 单字段主键
字段名 数据类型 PRIMARY KEY [默认值]
* 多字段联合主键
PRIMARY KEY [字段1, 字段2,. . ., 字段n]
## 4.1.3 使用外键约束
* 外键用来在两个表的数据之间建立链接,它可以是一列或者多列。一个表可以有一个或多个外键。一个表的外键可以为空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值。
~~~
[CONSTRAINT <外键名>] FOREIGN KEY 列名1 [ ,列名2,…]
REFERENCES <主表名> 主键列1 [ ,主键列2,…]
![](https://box.kancloud.cn/ca8747492354783f0bdffaaf11312be6_789x188.png)
~~~
## 4.1.4 使用非空约束
* 非空约束(Not Null constraint)指字段的值不能为空。对于使用了非空约束的字段如果用户在添加数据时,没有指定值,数据库系统会报错。
**字段名 数据类型 not null**
## 4.1.5 使用唯一性约束
* 唯一性约束(Unique Constraint)要求该列唯一,允许为空,但只能出现一个空值。唯一约束可以确保一列或者几列不出现重复值。
**字段名 数据类型 UNIQUE**
## 4.1.6 使用默认约束
* 默认约束(Default Constraint)指定某列 的默认值。
**字段名 数据类型 DEFAULT 默认值**
## 4.1.7 设置表的属性值自动增加
* 在数据库应用中,经常希望在每次插入新记录时,系统就会自动生成字段的主键值。可以通过为表主键添加AUTO_INCREMENT关键字来实现。一个表只能有一个字段使用AUTO_INCREMENT约束,且该字段必须为主键的一部分。
**字段名 数据类型 AUTO_INCREMENT**
# 4.2 查看数据表结构
## 4.2.1 查看表基本结构语句DESCRIBE
* 该语句可以查看表的字段信息,其中包括:字段名、字段数据类型、是否为主键、是否有默认值等。
**DESCRIBE <表名>/DESC <表名>**
## 4.2.2 查看表详细结构语句SHOW CREATE TABLE
* 语句可以用来显示数据表的创建语句。
**SHOW CREATE TABLE <表名\G>**
# 4.3 修改数据表
## 4.3.1 修改表名
* MySQL是通过ALTER TABLE语句来实现表名的修改的。
**ALTER TABLE <旧表名> RENAME [TO] <新表名>**
## 4.3.2 修改字段的数据类型
* 修改字段的数据类型,就是把字段的数据类型转换成另一种数据类型。*
**ALTER TABLE <表名> MODIFY <字段名><数据类型>**
## 4.3.3 修改字段名
* MySQL中修改表字段名的语法规则如下:
**ALTER TABLE <表名>
CHANGE <旧字段名> <新字段名> <新数据类型>;**
## 4.3.4 添加字段
* 在已经存在的表添加新的字段。
**ALTER TABLE <表名>
ADD <新字段名> <数据类型>
[约束条件] [FIRST | AFTER 已存在字段名];**
## 4.3.5 删除字段
* 删除字段是将数据表中的某个字段从表中移除。
**ALTER TABLE <表名> DROP <字段名>;**
## 4.3.6 修改字段的排列位置
* ALTER TABLE来改变表中字段的相对位置。
**ALTER TABLE <表名>
MODIFY <字段1> <数据类型> FIRST|AFTER <字段2>;**
## 4.3.7 更改表的存储引擎
* 在MySQL中,存储引擎是指MySQL数据库中表的存储类型。可以根据自己的需要,选择不同的引擎,甚至可以为每一张表选择不同的存储引擎。
**ALTER TABLE <表名> ENGINE=<更改后的存储引擎>;**
## 4.3.8 删除表的外键约束
* 对于数据库中定义的外键,如果不再需要,可以将其删除。外键一旦删除,就会解除主表和从表间的关联关系。
**ALTER TABLE <表名> DROP FOREIGN KEY <外键约束名>**
# 4.4 删除数据表
## 4.4.1 删除没有被关联的表
* MySQL中,使用DROP TABLE可以一次删除一个或多个没有被其它表关联的数据表。
**DROP TABLE [IF EXISTS]表1, 表2, . . . 表n;**
## 4.4.2 删除被其它表关联的主表
* 在数据表之间存在外键关联的情况下,如果直接删除父表,结果会显示失败,原因是直接删除,将破坏表的参照完整性。如果必须要删除,可以先删除与之关联的子表,再删除父表。但是这样同时删除了两个表中的数据。但有的情况下可能要保留子表,这时如要单独删除父表,只需将关联的表的外键约束条件取消,然后就可以删除父表。
# 4.5 综合案例——数据表的基本操作
* 数据表的创建和基本操作
* 本章全面介绍了MySQL中数据表的各种操作,如创建表、添加各类约束、查看表结构,以及修改和删除表。读者应该掌握这些基本的操作,为以后的学习打下坚实的基础。在这里,给出一个综合案例,让读者全面回顾一下本章的知识要点,并通过这些操作来检验自己是否已经掌握了数据表的常用操作。