对于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的权限。