SHOW CREATE TABLE 表名; 可完整获取建表语句,含字段、主键、索引、字符集、引擎等全部信息,返回Table和Create Table两列,表名被反引号包裹,需有SELECT权限。

在 MySQL 中查看某张表的建表语句,最直接、最常用的方法就是使用 SHOW CREATE TABLE 命令。它能完整还原创建该表时所用的 SQL 语句,包括字段定义、主键、索引、字符集、存储引擎等全部信息,对排查问题、迁移表结构或备份建表逻辑非常有用。
基本语法与执行方式
只需一条简单命令即可获取建表语句:
SHOW CREATE TABLE 表名;- 例如:
SHOW CREATE TABLE users; - 注意:表名不加引号(除非含特殊字符或关键字),且需确保当前数据库已选定(或使用
database_name.table_name全限定名)
常见注意事项
执行后返回两列结果:Table(表名)和 Create Table(建表语句)。需特别留意以下几点:
- 返回的 SQL 中,表名默认被反引号包裹(如
`users`),这是为兼容保留字或含特殊字符的表名,可直接复制使用 - 若表不存在,会提示
ERROR 1146 (42S02): Table 'xxx' doesn't exist - 执行用户需对该表有
SELECT权限(部分旧版本要求SHOW VIEW权限) - 结果中的换行和缩进是格式化输出,实际语句中空格和换行不影响执行
配合其他命令提升效率
单独查一张表很便捷,但日常运维中常需批量操作或快速定位:
- 先查表是否存在:
SHOW TABLES LIKE 'user%'; - 查当前库所有表的建表语句(逐条执行):
SELECT CONCAT('SHOW CREATE TABLE `', table_name, '`;') FROM information_schema.tables WHERE table_schema = DATABASE() AND table_name LIKE 'user%';,再复制结果运行 - 导出为文件(命令行下):
mysqldump -d -n -t --skip-triggers 数据库名 表名 > create_table.sql(-d表示不导数据,只导结构)
与 DESCRIBE / SHOW COLUMNS 的区别
别把 SHOW CREATE TABLE 和结构简览命令混淆:
-
DESCRIBE 表名;或SHOW COLUMNS FROM 表名;只显示字段名、类型、是否为空、键类型、默认值等基本信息,不含索引、外键、引擎、字符集等完整定义 -
SHOW CREATE TABLE是唯一能拿到「可直接执行的建表语句」的方式,适合复现、迁移、审计场景










