手机端小强原创文章,java小强个人博客站点
当前位置: 首页 >> DB >> MySQL的create table as 与 like区别

MySQL的create table as 与 like区别

14151 DB | 2016-6-22

对于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用来创建完整表结构和全部索引。


MySQL的create table as 与 like区别


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

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


推荐您阅读更多有关于“ mysql table create ”的文章

上一篇:mmseg4j中的MMSeg4jHandler,动态加载词库 下一篇:Solr常用函数和实际使用

猜你喜欢

发表评论:

评论:

回复 教室网 评论于 2016-07-26 15:34
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.
个人资料
blogger

java小强
没有思考,人生的路会越走越难!

搜索
百度推荐
分类
百度推荐
最新文章
搜狗推荐
热门文章
百度推荐
随机文章