MySQL的create table as 与 like区别

Posted 飘雪啦

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQL的create table as 与 like区别相关的知识,希望对你有一定的参考价值。

对于mysql的复制相同表结构方法,有create table as 和create table like 两种,区别是什么呢?

 

1
create table t2 as select from t1 where 1=2;

或者 limit 0;

as创建出来的t2表(新表)缺少t1表(源表)的索引信息,只有表结构相同,没有索引。

 

1
create table t2 like t1 ;

like 创建出来的新表包含源表的完整表结构和索引信息。

 

二者的用途:

as用来创建相同表结构并复制源表数据。

like用来创建完整表结构和全部索引。

oracle支持as,也是只有表结构没有索引,oracle不支持like。

两种方式在复制表的时候均不会复制权限对表的设置。比如说原本对表B做了权限设置,复制后,表A不具备类似于表B的权限。

以上是关于MySQL的create table as 与 like区别的主要内容,如果未能解决你的问题,请参考以下文章

MySQL的create table as 与 like区别

MySQL中表复制:create table like 与 create table as select

MySQL中create table as 与like的区别分析

mysql复制表结构create table as和like的区别

何时将 CREATE TABLE AS SELECT 与 CREATE TABLE LIKE?

create table as 和create table like的区别