MySQL create table as与create table like对比
Posted lovely可爱欧辰
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL create table as与create table like对比相关的知识,希望对你有一定的参考价值。
对于mysql的复制相同表结构方法,有create table as 和create table like 两种,区别是什么呢?
create table t2 as select * from t1 where 1=2 ; 或者 limit 0;
as创建出来的t2表(新表)缺少t1表(源表)的索引信息,只有表结构相同,没有索引。
create table t2 like t1 ;
like 创建出来的新表包含源表的完整表结构和索引信息
二者的用途:
as用来创建相同表结构并复制源表数据
like用来创建完整表结构和全部索引
————————————————
a、create table like方式会完整地克隆表结构,但不会插入数据,需要单独使用insert into或load data方式加载数据
b、create table as 方式会部分克隆表结构,完整保留数据
c、create table as select .. where 1=0 会克隆部分表结构,但不克隆数据。
d、如果启用了gtid,create table as方式不被支持。收到ERROR 1786 (HY000): CREATE TABLE ... SELECT is forbidden when @@GLOBAL.ENFORCE_GTID_CONSISTENCY = 1.
————————————————
以上是关于MySQL create table as与create table like对比的主要内容,如果未能解决你的问题,请参考以下文章
MySQL的create table as 与 like区别
MySQL中表复制:create table like 与 create table as select
MySQL中create table as 与like的区别分析
mysql复制表结构create table as和like的区别