MySQL——数据表的基本操作(三)修改数据表

有时候,希望对表中的某些信息进行修改,这时就需要修改数据表。所谓修改数据表指的是修改数据库中已经存在的数据表结构,比如,修改表名、修改字段名、修改字段的数据类型等。在 MySQL中,修改数据表的操作都是使用 ALTER TABLE 语句,接下来,将针对修改数据表的相关操作进行详细的讲解,具体如下。

1.修改表名

在数据库中,不同的数据表是通过表名来区分的。在 MySQL中,修改表名的基本语法格式如下所示:

sql 复制代码
ALTER TABLE 旧表名 RENAME[TO]新表名;

在上述格式中,"旧表名"指的是修改前的表名,"新表名"指的是修改后的表名,关键字 TO 是可选的,其在 SQL语句中是否出现不会影响语句的执行。

例如,将数据库 itcast 中的 tb_grade 表名改为 grade 表。在修改数据库表名之前,首先使用 SHOW TABLES 语句查看数据库中的所有表,执行结果如下:

sql 复制代码
mysql> show tables;
+------------------+
| Tables_in_itcast |
+------------------+
| tb_grade         |
+------------------+
1 row in set (0.01 sec)

上述语句执行完毕后,使用 ALTER TABLE 将表名 tb_grade 修改为 grade,SQL 语句如下:

sql 复制代码
mysql>ALTER TABLE tb_grade RENAME To grade;
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了检测表名是否修改正确,再次使用 SHOW TABLES 语句查看数据库中的所有表,执行结果如下所示:

sql 复制代码
mysql> show tables;
+------------------+
| Tables_in_itcast |
+------------------+
| grade            |
+------------------+
1 row in set (0.00 sec)

从上述执行结果可以看出,数据库中的 tb_grade 表名被成功修改为 grade 了。

2.修改字段名

数据表中的字段是通过字段名来区分的。在 MySQL中,修改字段名的基本语法格式如下所示:

sql 复制代码
ALTER TABLE 表名 CHANGE 旧日字段名 新字段名 新数据类型;

在上述格式中,"旧字段名"指的是修改前的字段名,"新字段名"指的是修改后的字段名,"新数据类型" 指的是修改后的数据类型。需要注意的是,新数据类型不能为空,即使新字段与旧字段的数据类型相同,也必须将新数据类型设置为与原来一样的数据类型。

例如,将数据表 grade 中的 name 字段改为 username,数据类型保持不变,SQL语句如下所示:

sql 复制代码
mysql> ALTER TABLE grade CHANGE name username VARCHAR(20);
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了验证字段名是否修改成功,通过 DESC 语句查看 grade 表的结构,执行结果如下所示:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | YES  |     | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.01 sec)

从上述执行结果可以看出,数据表 grade 中的字段名 name 被成功修改成了username.

3.修改字段的数据类型

修改字段的数据类型,就是将字段的数据类型转为另外一种数据类型。在MySQL中修改字段数据类型的基本语法格式如下所示:

sql 复制代码
ALTER TABLE 表名 MODIFY 字段名 数据类型;

在上述格式中,"表名"指的是要修改字段所在的表名,"字段名"指的是要修改的字段,"数据类型"指的是修改后的字段的数据类型。

例如,将数据表 grade 中的 id 字段的数据类型由 INT(11) 修改为 INT(20)在执行修改字段的数据类型之前,首先使用 DESC 查看 grade 表的结构,如下所示:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(11)     | YES  |     | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

从上述执行结果可以看出,id字段的数据类型为 INT(11)。接下来,使用 ALTER语句修改id字段的数据类型,SQL语句如下所示:

sql 复制代码
mysql> ALTER TABLE grade MODIFY id INT(20);
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了验证 id字段的数据类型是否修改成功,再次使用 DECS 查看 grade 数据表,执行结果如下:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(20)     | YES  |     | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

从上述结果可以看出,grade表中的[d字段的数据类型被成功修改成了INT(20)。

4.添加字段

在创建数据表时,表中的字段就已经定义好了。但是,如果想在创建好的数据表中添加字段,则需要通过 ALTER TABLE 语句进行增加。在 MySQL 中,添加字段的基本语法格式如下所示:

sql 复制代码
ALTER TABLE 表名 ADD 新字段名 数据类型
    [约束条件][FIRST|APTER 已存在字段名]

在上述格式中,"新字段名" 为添加字段的名称,"FIRST "为可选参数,用于将新添加的字段设置为表的第一个字段,"AFTER" 也为可选参数,用于将新添加的字段添加到指定的 "已存在字段名" 的后面。

例如,在数据表 grade 中添加一个没有约東条件的 INT 类型的字段 age,SQL语句如下:

sql 复制代码
ALTER TABLE grade ADD age INT (10);

为了验证字段 age 是否添加成功,接下来,使用 DESC 语句查看数据表 grade,执行结果如下:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(20)     | YES  |     | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
| age      | int(10)     | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

从上述执行结果可以看出,grade表中添加了一个 age 字段,并且字段的数据类型为INT(10)。

5.删除字段

数据表创建成功后,不仅可以修改字段,还可以删除字段。所谓删除字段指的是将某个字段从表中删除。在 MySQL中,删除字段的基本语法格式如下所示:

sql 复制代码
ALTER TABLE 表名 DROP 字段名;

在上述格式中,"字段名"指的是要删除的字段的名称,例如,删除 grade 表中的 age 字段,SQL 语句如下:

sql 复制代码
mysql> ALTER TABLE grade DROP age;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了验证 age 字段是否删除,接下来,使用 DESC 语句查看 grade表,执行结果如下:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id       | int(20)     | YES  |     | NULL    |       |
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

从上述执行结果可以看出,grade表中已经不存在 age 字段,说明 age 字段被成功删除了。

6.修改字段的排列位置

创建数据表的数据,字段在表中的位置已经确定了。但要修改字段在表中的排列位置,则需要使用 ALTER TABLE语句来处理。在 MySQL中,修改字段排列位置的基本语法格式如下:

sql 复制代码
ALTER TABLE 表名 MODIFY 字段名1 数据类型 FIRST|AFTER 字段名 2

在上述格式中,"字段名1"指的是修改位置的字段,"数据类型"指的是字段1的数据类型,"FIRST"为可选参数,的是将字段1修改为表的第一个字段,"AFTER 字段名2是将字段1插入到字段2的后面。

例如,将数据表 grade 的 username 字段修改为表的第一个字段,执行的 SQL语句如下:

sql 复制代码
mysql> ALTER TABLE grade MODIFY username VARCHAR(20) FIRST;
Query OK, 0 rows affected (0.02 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了验证 username 字段是否修改为表的第一个字段,接下来,使用 DESC 语句查看数据表,执行结果如下:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| username | varchar(20) | YES  |     | NULL    |       |
| id       | int(20)     | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.01 sec)

从上述执行结果可以看出,username字段为表的第一个字段,说明 username 字段的排列位置被成功修改了。

例如,将数据表 grade 的 id 字段插入到 grade 字段后面,执行的 SQL 语句如下:

sql 复制代码
mysql> ALTER TABLE grade MODIFY id INT(20) AFTER grade;
Query OK, 0 rows affected (0.01 sec)
Records: 0  Duplicates: 0  Warnings: 0

为了验证 id 字段是否插入到 grade 字段后面,接下来,使用 DESC 语句查看数据表执行结果如下:

sql 复制代码
mysql> desc grade;
+----------+-------------+------+-----+---------+-------+
| Field    | Type        | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| username | varchar(20) | YES  |     | NULL    |       |
| grade    | float       | YES  |     | NULL    |       |
| id       | int(20)     | YES  |     | NULL    |       |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.01 sec)

从上述结果可以看出,id 字段位于 grade 字段后面,说明 id 字段的排列位置被成功修改了。

相关推荐
玄同765几秒前
SQLite + LLM:大模型应用落地的轻量级数据存储方案
jvm·数据库·人工智能·python·语言模型·sqlite·知识图谱
吾日三省吾码2 分钟前
别只会“加索引”了!这 3 个 PostgreSQL 反常识优化,能把性能和成本一起打下来
数据库·postgresql
chian-ocean3 分钟前
百万级图文检索实战:`ops-transformer` + 向量数据库构建语义搜索引擎
数据库·搜索引擎·transformer
那个村的李富贵23 分钟前
解锁CANN仓库核心能力:50行代码搭建国产化AIGC图片风格迁移神器
mysql·信息可视化·aigc·cann
小Tomkk23 分钟前
数据库 变更和版本控制管理工具 --Bytebase 安装部署(linux 安装篇)
linux·运维·数据库·ci/cd·bytebase
qq_12498707531 小时前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
倒流时光三十年1 小时前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉2 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣502 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx2 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt