mysql中SELECT INTO创建新表的基本语法

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

MySQL 不支持

SELECT INTO
语法来创建新表——这是 SQL Server 和 PostgreSQL 支持的写法,直接在 MySQL 中执行会报错
ERROR 1064 (42000)

MySQL 创建新表并插入数据的等效写法是
CREATE TABLE ... AS SELECT

这是 MySQL 原生且最常用的方式,它能同时完成「建表结构 + 插入数据」两件事:

表结构由
SELECT
的列名、类型和是否允许 NULL 自动推导(不复制 KEY、INDEX、COMMENT 等元信息)
如果只想建表结构但不插入数据,加
WHERE 1=0
LIMIT 0
不支持指定存储引擎或字符集?可以后续用
ALTER TABLE
补上,或在
CREATE
语句中显式声明
CREATE TABLE new_table AS
SELECT id, name, created_at FROM users WHERE status = 'active';
CREATE TABLE empty_copy AS
SELECT * FROM original_table WHERE 1=0;

为什么不能用
SELECT ... INTO new_table

MySQL 的

INTO
关键字仅用于变量赋值(如存储过程)或导出文件(
INTO OUTFILE
),不是建表语法:

SELECT col INTO @var FROM t;
✅ 合法:赋值给用户变量
SELECT * INTO OUTFILE '/tmp/data.csv' FROM t;
✅ 合法:导出到文件
SELECT * INTO new_table FROM t;
❌ 报错:
You have an error in your SQL syntax

想保留主键、索引或注释?得拆成两步

CREATE TABLE ... AS SELECT
只拷贝数据和基础列定义,不会复制约束和索引。若需完整结构,推荐:

先用
SHOW CREATE TABLE original_table
查看建表语句
手动修改表名,并替换
CREATE TABLE
CREATE TABLE new_table LIKE original_table
(复制结构,含 KEY)
再用
INSERT INTO new_table SELECT ...
插入数据
CREATE TABLE new_table LIKE original_table;
INSERT INTO new_table SELECT * FROM original_table WHERE condition;

真正容易被忽略的是:即使列类型看起来一样,

AS SELECT
可能将
TINYINT(1)
转成
TINYINT(255)
,或丢失
DEFAULT
COMMENT
。需要精确复刻时,别图省事。

相关推荐