如何在mysql中查看建表SQL_mysql show create table用法

来源:这里教程网 时间:2026-02-28 20:41:46 作者:

在 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
是唯一能拿到「可直接执行的建表语句」的方式,适合复现、迁移、审计场景

相关推荐