您的位置:首页 > 数据库 > MySQL

mysql 之as 与 like创建表之差异

2016-05-23 10:02 323 查看
对于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用来创建完整表结构和全部索引

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

同时,还发现like创建的表是没数据的。。。

同时自己的一个突然的想法,插入数据到like出来的表(说明t1是存在数据的,id,name id自增),做了如下测试

1,这种写法是可行的

create table tmp3 like t1

insert into tmp3 values (null,'aa');

2,连起来就报错了

insert into (create table tmp3 like t1) values (null,'aa');
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  mysql as