• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
飘雪啦
寒冬来临
   首页    新随笔       管理     

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

posted @ 2016-12-28 16:33  飘雪啦  阅读(4903)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3