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);
相关推荐
SelectDB13 小时前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶14 小时前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构
掉头发的王富贵17 小时前
【StarRocks】极限十分钟入门StarRocks
数据库·sql·mysql
Nturmoils17 小时前
WHERE 条件别凭习惯写,常用查询先跑一遍
数据库
SamDeepThinking21 小时前
一条UPDATE语句在MySQL 8.0中到底加了几把锁?
后端·mysql·程序员
Databend2 天前
在 AWS 中国峰会逛了一天,我在 Databend 展台看到了 Agent 数据基础设施的新思路
数据库·人工智能·agent
李白客3 天前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
ClouGence3 天前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将3 天前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils4 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库