MySQL表的操作:创建—修改—删除流程解析

文章目录

在MySQL数据库日常开发中,表是数据存储的核心载体。无论是创建表、查看结构,还是修改字段、删除表,每一步操作都有规范的语法和潜在的坑点。本文介绍MySQL表的完整操作...

1 创建表

创建表是数据存储的第一步,需明确列名、数据类型、字符集和存储引擎,语法结构固定且严谨。

语法格式

sql 复制代码
CREATE TABLE table_name (
  field1 datatype,
  field2 datatype,
  field3 datatype
) character set 字符集 collate 校验规则 engine 存储引擎;

关键说明

  • field:表的列名,需体现列的业务含义(如id表示主键、name表示用户名);
  • datatype:列的数据类型(如int存整数、varchar(20)存短字符串、date存日期);(后续会详细讲解数据类型)
  • character set:表的字符集(若不指定,默认继承所在数据库的字符集);
  • collate:字符校验规则(若不指定,默认继承数据库规则);
  • engine:存储引擎(MySQL常用MyISAMInnoDB,两者文件存储差异极大)。

注意: 不同存储引擎在磁盘上生成的文件不同,若不清楚差异,可能误删或找不到数据:

  • 当存储引擎为MyISAM时,会生成3个文件:
    • 表名.frm:存储表结构;
    • 表名.MYD:存储表数据;
    • 表名.MYI:存储表索引;
  • 当存储引擎为InnoDB时(MySQL 5.7及以上),会生成2个文件:
    • 表名.frm:存储表结构;
    • 表名.ibd:存储表数据+索引(InnoDB将数据和索引融合存储)。

2 创建users表

以创建"用户表users"为例,指定存储引擎为MyISAM、字符集为utf8,包含用户ID、用户名、加密密码、生日字段。

SQL

sql 复制代码
create table users (
  id int,
  name varchar(20) comment '用户名',  -- 注释说明字段含义,便于维护
  password char(32) comment '密码是32位的md5值',  -- MD5加密后固定32位,用char更高效
  birthday date comment '生日'
) character set utf8 engine MyISAM;

验证

执行上述SQL后,在MySQL数据目录(如C:\ProgramData\MySQL\MySQL Server5.7\Data\test1)中,会看到3个文件:

文件名 类型 作用 大小
users.frm FRM文件 存储users表结构 9KB
users.MYD MYD文件 存储users表数据 0KB(暂无数据)
users.MYI MYI文件 存储users表索引 1KB

3 查看表结构

创建表后,需确认表结构是否符合预期,MySQL提供desc命令快速查看列名、类型、是否允许为空等信息。

语法与示例

sql 复制代码
-- 语法:desc 表名;
desc users;

字段分析

Field Type Null Key Default Extra
id int(11) YES NULL
name varchar(20) YES NULL
password char(32) YES NULL
birthday date YES NULL

各列含义:(如果是初学者了解即可,数据类型会详解)

  • Field:列名;
  • Type:列的数据类型(如int(11)表示整数,varchar(20)表示最大20位字符串);
  • Null:是否允许为空(YES表示允许,NO表示不允许);
  • Key:是否为索引(空表示非索引,PRI表示主键,UNI表示唯一索引);
  • Default:默认值;
  • Extra:额外信息(如auto_increment表示自增)。

其他语句

  • descshow create table
    desc仅显示简化的表结构,若需查看完整创建语句(含字符集、存储引擎),需用show create table 表名;,例如:

    sql 复制代码
    show create table users;

    执行后会返回完整的CREATE TABLE语句,便于复现表结构。

3.4 修改表

实际开发中,表结构常需调整(如加字段、改类型、删列、改表名),MySQL用ALTER TABLE命令实现,不同修改场景语法不同,且需注意数据安全性

3.4.1 添加字段

需求:在users表的birthday字段后,新增assets字段存储图片路径。

SQL
sql 复制代码
-- 语法:ALTER TABLE 表名 ADD 字段名 类型 [comment '注释'] [after 已有字段名];
alter table users add assets varchar(100) comment '图片路径' after birthday;
验证
  1. 查看修改后的结构:

    sql 复制代码
    desc users;

    会新增assets列,位于birthday之后:

    Field Type Null Key Default Extra
    ... ... ... ... ... ...
    birthday date YES NULL
    assets varchar(100) YES NULL
  2. 对原有数据无影响:

    sql 复制代码
    select * from users;

    原有2条数据的assets列值为NULL(新增字段默认无值),但不会丢失旧数据:

    id name password birthday assets
    1 a b 1982-01-04 NULL
    2 b c 1984-01-04 NULL

3.4.2 修改字段类型/长度

需求:将name字段的长度从varchar(20)改为varchar(60)(应对更长的用户名需求)。

SQL
sql 复制代码
-- 语法:ALTER TABLE 表名 MODIFY 字段名 新类型;
alter table users modify name varchar(60);
验证
sql 复制代码
desc users;

name字段的Type会变为varchar(60),原有用户名数据不会丢失。

3.4.3 删除字段(谨慎操作!)

需求:删除password字段(假设密码存储逻辑变更,不再需要该列)。

SQL
sql 复制代码
-- 语法:ALTER TABLE 表名 DROP 字段名;
alter table users drop password;
验证
sql 复制代码
desc users;

password列会被彻底删除,且该列的所有数据也会丢失,无法恢复!

3.4.4 修改表名

需求:将users表改名为employee(表的业务含义变更)。

SQL
sql 复制代码
-- 语法:ALTER TABLE 旧表名 RENAME [TO] 新表名;(TO可省略)
alter table users rename to employee;
验证
sql 复制代码
-- 查看新表名的数据
select * from employee;

会正常返回原users表的数据,表名已更新。

3.4.5 修改列名

需求:将employee表的name列改名为xingming,保持类型为varchar(60)

SQL
sql 复制代码
-- 语法:ALTER TABLE 表名 CHANGE 旧列名 新列名 完整类型;(必须指定完整类型)
alter table employee change name xingming varchar(60);
验证
sql 复制代码
desc employee;

name列会变为xingming,类型仍为varchar(60)

区别分析

  1. MODIFYCHANGE

    • MODIFY:仅修改字段类型/长度,不修改列名,语法为MODIFY 字段名 新类型
    • CHANGE:可同时修改列名和类型,语法为CHANGE 旧列名 新列名 完整类型(必须写新列名和完整类型,缺一不可);
      错误示例:用change改长度却不写新列名:
    sql 复制代码
    -- 错误!CHANGE必须指定旧列名和新列名
    alter table employee change name varchar(60);
  2. 添加字段时未指定位置,默认在最后

    若不写after 已有字段名,新增字段会默认放在表的最后一列。若需指定位置(如在id后),需明确写after id,例如:

    sql 复制代码
    alter table employee add age int comment '年龄' after id;

3.5 删除表

当表不再需要时,可使用DROP TABLE命令删除,但表的结构、数据、索引会全部删除,无法恢复。

语法格式

sql 复制代码
DROP [TEMPORARY] TABLE [IF EXISTS] tbl_name [, tbl_name] ...;
  • TEMPORARY:仅删除临时表(避免误删永久表);
  • IF EXISTS:若表不存在,不报错(否则会报"表不存在"错误);
  • 可同时删除多个表,用逗号分隔。

SQL

sql 复制代码
drop table employee;

验证

sql 复制代码
#查看表数据
select * from employee;
相关推荐
做运维的阿瑞2 小时前
PostgreSQL 从入门到精通:Windows 环境下安装与使用指南
数据库·windows·postgresql
学编程的小鬼2 小时前
MySQL的快速入门
数据库·mysql
_Power_Y2 小时前
MySql复习及面试题学习
数据库·学习·mysql
学习编程的Kitty2 小时前
MySQL——数据类型和表的操作
数据库·mysql
程序新视界3 小时前
MySQL中,日期、时间与时间戳三种数据类型的区别
数据库·后端·mysql
lang201509283 小时前
MySQL 8.0性能优化终极指南
数据库·mysql·性能优化
苹果醋33 小时前
数据结构其一 线性表
java·运维·spring boot·mysql·nginx
Elastic 中国社区官方博客3 小时前
在 Elasticsearch 中改进 Agentic AI 工具的实验
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
豆沙沙包?3 小时前
2025年--Lc172--H178 .分数排名(SQL)--Java版
数据库·sql