mysql table as_Mysql中create table as与like命令的区别

MySQL 是一种关联数据库管理系统,关联数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。MySQL 所使用的 SQL 语言是用于访问数据库的最常用标准化语言。在做数据迁移时,对于mysql中复制相同表结构方式有create table as select与create table like 两种方式,具体分析如下。

慎用create table as select,一定要注意默认值的问题,在做数据迁移时,很多人会使用create table  as select * from table where id=-1的方式来建立相同的表,但是这样做有个很大的弊端,不能将原表中的默认值(default value)也一同迁移过来。

1、创建新表,具体代码如下:create table table1

(

idint,

dateTime  date default sysdate,

status    int,

code      varchar

)

2、使用 create table table2 as select * From table1 where id=-1 命令创建,as创建出来的table2 缺少table1表(源表)的索引信息,只有表结构相同,没有索引。

3、使用 create table table3 like table1; 命令创建,like 创建出来的table3包含table1(源表)的完整表结构和索引信息。

create table as与like命令,二者的应用场景:

1)create table as用来创建相同表结构并复制源表数据;

2)create table like用来创建完整表结构和全部索引;

3)oracle支持create table as,也是只有表结构没有索引,但是oracle不支持create table like。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值