MySQL DDL简介

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;

关键特性

  1. 自动提交
    在 MySQL 中,默认情况下每条 DDL 语句执行后会立即自动提交,无法回滚(除非在事务中显式关闭自动提交,且存储引擎为 InnoDB 并开启了事务 DDL 支持)。
    ⚠️ 早期版本或某些存储引擎(如 MyISAM)下 DDL 是非事务性的,但在 MySQL 8.0+ 中,InnoDB 的多数 DDL 操作支持原子性(要么完全成功,要么完全回滚)。
  2. 锁行为
    • 传统 DDL 操作会元数据锁,可能阻塞并发查询或 DML。
    • MySQL 5.6+ 引入了 在线 DDL 特性(ALGORITHM=INPLACE),允许某些 ALTER 操作在不完全阻塞读写的情况下执行。
  3. 影响范围
    • 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);
相关推荐
2301_8159019725 分钟前
C#怎么使用协变和逆变 C#泛型中的in和out关键字协变逆变是什么意思怎么用【语法】
jvm·数据库·python
m0_4636722028 分钟前
SQL优化SQL关联查询中的排序字段_减少临时空间占用与内存开销
jvm·数据库·python
我叫Double32 分钟前
简易版的EINO基于redis库的向量搜索项目v2
数据库·redis·bootstrap
iuvtsrt1 小时前
存储过程如何处理海量数据的批处理_循环提交与分段LIMIT结合
jvm·数据库·python
yexuhgu1 小时前
SQL如何检查字符串是否存在:INSTR与LOCATE函数使用
jvm·数据库·python
2301_783848651 小时前
SQL如何用SQL子查询实现关联报表生成_嵌套逻辑关联多表
jvm·数据库·python
techdashen2 小时前
dial9:给 Tokio 装上“飞行记录仪“
java·数据库·redis
2501_901006472 小时前
Golang怎么用gRPC Gateway_Golang gRPC Gateway教程【经典】
jvm·数据库·python
2501_901200532 小时前
golang如何实现错误预算Error Budget计算_golang错误预算Error Budget计算实现实战
jvm·数据库·python
2401_867623982 小时前
如何解决OUI图形界面无法调用_xhost与DISPLAY变量设置
jvm·数据库·python