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);
相关推荐
ClouGence2 小时前
从 OLTP 到 OLAP:Spanner 到 StarRocks 架构演进与实现
大数据·数据库·starrocks·olap·dba·oltp·spanner
qiuyunoqy2 小时前
Redis 常见数据结构,编码方式
数据库·redis·缓存
qq_424098562 小时前
HTML5中解决数据库版本号管理混乱的规范化建议
jvm·数据库·python
Irene19912 小时前
Python下载第三方库:requests、oracledb,连接 Oracle 数据库,测试数据输出(切记不要操作或删除系统表)
数据库·python·oracledb
四维迁跃2 小时前
HTML5中SVG利用Javascript实现图形拖拽与缩放
jvm·数据库·python
我们的五年2 小时前
mysql报错,net_async_status
数据库·mysql·adb
hINs IONN2 小时前
在Mysql环境下对数据进行增删改查
数据库·mysql
Chuer_2 小时前
AI For BI是什么?一文拆解AI For BI应用落地!
大数据·数据库·人工智能·安全·数据分析·甘特图
梵高的向日葵�2392 小时前
OpenCV+MySQL+Qt构建智能视觉系统(msvc)
qt·opencv·mysql