🔥码云GVP开源项目 12k star Uniapp+ElementUI 功能强大 支持多语言、二开方便! 广告
# 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中数据表的各种操作,如创建表、添加各类约束、查看表结构,以及修改和删除表。读者应该掌握这些基本的操作,为以后的学习打下坚实的基础。在这里,给出一个综合案例,让读者全面回顾一下本章的知识要点,并通过这些操作来检验自己是否已经掌握了数据表的常用操作。