DDL(Data Definition Language,数据定义语言)是 SQL 的一个子集,用于定义和管理数据库结构,如数据库、表、索引、视图等。在 MySQL 中,DDL 语句通常涉及创建、修改、删除数据库对象。
主要 DDL 命令
| 命令 | 作用 | 示例 |
|---|---|---|
| CREATE | 创建数据库、表、索引、视图等 | CREATE DATABASE db1; CREATE TABLE t1 (id INT); |
| ALTER | 修改已有对象的结构(添加列、修改类型、重命名等) | ALTER TABLE t1 ADD COLUMN name VARCHAR(50); |
| DROP | 删除整个数据库或表(结构+数据) | DROP TABLE t1; |
| TRUNCATE | 清空表的所有行,但保留表结构(相当于删除并重建表) | TRUNCATE TABLE t1; |
| RENAME | 重命名表 | RENAME TABLE t1 TO t2; |
关键特性
- 自动提交
在 MySQL 中,默认情况下每条 DDL 语句执行后会立即自动提交,无法回滚(除非在事务中显式关闭自动提交,且存储引擎为 InnoDB 并开启了事务 DDL 支持)。
⚠️ 早期版本或某些存储引擎(如 MyISAM)下 DDL 是非事务性的,但在 MySQL 8.0+ 中,InnoDB 的多数 DDL 操作支持原子性(要么完全成功,要么完全回滚)。 - 锁行为
- 传统 DDL 操作会元数据锁,可能阻塞并发查询或 DML。
- MySQL 5.6+ 引入了 在线 DDL 特性(ALGORITHM=INPLACE),允许某些 ALTER 操作在不完全阻塞读写的情况下执行。
- 影响范围
- DROP 与 TRUNCATE 无法恢复数据(除非有备份)。
- TRUNCATE 比 DELETE 更快,因为它不逐行删除,而是直接重置数据页。
常用示例
sql
--创建数据库
CREATE DATABASE school;
USE school;
--创建表
CREATE TABLE students (
id INT PRIMARY KEY AUTO_INCREMENT,
name VARCHAR(100) NOT NULL,
age INT
);
--添加列
ALTER TABLE students ADD COLUMN email VARCHAR(100);