要获取 MySQL 中某个表的完整创建 DDL(仅结构,不含数据),可以使用 mysqldump
工具的以下命令:
基本命令格式
bash
mysqldump -h [主机名] -u [用户名] -p --no-data --single-transaction --routines --triggers --add-drop-table [数据库名] [表名]
实际示例(获取 class_students 表的 DDL)
bash
mysqldump -h localhost -u root -p --no-data --single-transaction --routines --triggers --add-drop-table --compact --complete-insert school_db class_students
参数说明
参数 | 说明 |
---|---|
-h | 指定 MySQL 主机地址 |
-u | 指定用户名 |
-p | 提示输入密码 |
--no-data | 只导出表结构,不导出数据 |
--single-transaction | 使用事务保证数据一致性 |
--routines | 包含存储过程和函数 |
--triggers | 包含触发器 |
--add-drop-table | 在 CREATE TABLE 前添加 DROP TABLE 语句 |
--compact | 产生更紧凑的输出 |
--complete-insert | 使用完整的 INSERT 语句格式 |
输出示例
执行命令后会得到类似这样的完整 DDL:
sql
DROP TABLE IF EXISTS `class_students`; /*!40101 SET @saved_cs_client = @@character_set_client */; /*!50503 SET character_set_client = utf8mb4 */; CREATE TABLE `class_students` (`student_id` int NOT NULL AUTO_INCREMENT,`student_name` varchar(50) NOT NULL,`gender` enum('男','女') NOT NULL,`age` tinyint unsigned NOT NULL,`birth_date` date DEFAULT NULL,`address` varchar(100) DEFAULT NULL,`phone` varchar(20) DEFAULT NULL,`email` varchar(50) DEFAULT NULL,`enrollment_date` date NOT NULL,`class_id` int NOT NULL,PRIMARY KEY (`student_id`),KEY `idx_class_id` (`class_id`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; /*!40101 SET character_set_client = @saved_cs_client */;
其他有用选项
-
获取更详细的元数据信息:
bash
mysqldump --no-data --tab=/tmp --fields-terminated-by=, --fields-enclosed-by='"' --lines-terminated-by=0x0d0a school_db class_students
-
将输出保存到文件:
bash
mysqldump -u root -p --no-data school_db class_students > class_students_ddl.sql
这样导出的 DDL 包含了完整的表结构定义,包括字段类型、约束、索引、存储引擎和字符集等信息,可以完全用于重建相同的表结构。