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);
相关推荐
TDengine (老段)15 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
苏渡苇16 小时前
Redis 持久化——RDB 快照 vs AOF 日志
数据库·redis·缓存·redis持久化·aof vs rdb
l1t17 小时前
DeepSeek总结的使用 PEG 实现运行时可扩展的 SQL 解析器
数据库·sql
这个DBA有点耶17 小时前
COUNT进阶(续):超大表去重计数的极致优化
数据库·架构·代码规范
爱喝水的鱼丶17 小时前
SAP-ABAP:SAP 简单报表输出开发系列(共6篇) 第四篇:SAP 报表异常处理机制:数据校验与消息提示规范落地
开发语言·数据库·学习·算法·sap·abap
_1_717 小时前
SQL SERVER闪退问题解决
数据库·sqlserver
ZengLiangYi17 小时前
sql.js WASM 深度解析
javascript·数据库·后端
一 乐17 小时前
人口老龄化社区服务与管理平台|基于springboot+vue的人口老龄化社区服务与管理平台(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·人口老龄化社区服务与管理平台
梓䈑18 小时前
【MySQL】表的操作(数据表的创建、查看 和 修改)
数据库·mysql
小碗羊肉18 小时前
【Redis | 第六篇】Redisson
数据库·redis·缓存