当前位置: 首页 > backend >正文

使用 mysqldump 获取 MySQL 表的完整创建 DDL

要获取 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 */;

其他有用选项

  1. 获取更详细的元数据信息:

bash

mysqldump --no-data --tab=/tmp --fields-terminated-by=, --fields-enclosed-by='"' --lines-terminated-by=0x0d0a school_db class_students
  1. 将输出保存到文件:

bash

mysqldump -u root -p --no-data school_db class_students > class_students_ddl.sql

这样导出的 DDL 包含了完整的表结构定义,包括字段类型、约束、索引、存储引擎和字符集等信息,可以完全用于重建相同的表结构。

http://www.xdnf.cn/news/9385.html

相关文章:

  • Spring AI(一)
  • windows 环境中 python连接到达梦库,及相关问题解决办法
  • TDengine 中的存储配置
  • 线程池详解:原理、使用与优化
  • 78. Subsets和90. Subsets II
  • Linux:基础指令与内涵理解(下)与权限
  • git 命令之-git cherry-pick
  • 短剧看广告APP系统开发:打造高效变现与用户体验双赢平台
  • 人工智能AI之机器学习基石系列 第 2 篇:数据为王——机器学习的燃料与预处理
  • JavaSE核心知识点04工具04-04(Git)
  • 专业教育机构视频网站平台播放器页面如何处理视频加密的?
  • [React]实现一个类zustand公共状态库
  • 2025上半年软考系统架构设计师选择题试题与答案
  • AI Agents执行流程和决策流程学习
  • 零基础设计模式——结构型模式 - 组合模式
  • RapidOCR4j项目学习
  • 润和星闪WS63E的MQTT示例程序存在的潜在问题
  • 经典查找算法合集(下)
  • 行为型:命令模式
  • 多语言实现插值查找算法
  • 理解vue-cli中的webpack
  • Minktec 柔性弯曲传感器,灵敏捕捉坐姿弓背、精准监测行走姿态,守护儿童背部健康,为科学健身提供数据支撑,开启职业健康与背痛 AI 干预新方向。
  • vue + ant-design + xlsx 实现Excel多Sheet页导出功能
  • 如何通过ETL对WebService进行调用
  • 顶会新方向:卡尔曼滤波+目标检测
  • Java 程序求圆弧段的面积(Program to find area of a Circular Segment)
  • Mico 1.33.1 | 解锁高级版 上千种自定义组件 动态壁纸
  • Java String函数的使用
  • 016搜索之广度优先BFS——算法备赛
  • word中表格拉不动以及插入图片有间距