mysql中复制表结构与数据的方法小结(5.7版本)

实践所用user表的DDl:

   CREATE TABLE `user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(255) NOT NULL,
  `password` varchar(255) NOT NULL,
  `state` bit(1) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;

1.只复制表结构到新表

create TABLE test SELECT * FROM `user`where 1=2;

主键,自增长等不会添加进去
  或者 使用

CREATE TABLE test like `user`;

没有数据,但是结构完全一样,推荐使用

2.复制表结构及数据到新表(结构不完整)

create TABLE test SELECT * FROM `user`;

有数据,但是主键,自增长等不会添加进去

3.复制旧表的数据到新表(假设两个表结构一样) 

Insert INTO test SELECT * from user;

test表必须先存在

#INSERT INTO test(id,username)  SELECT id,username FROM `user`;2个表结构不一样,插入test表中部分数据.注意没有插入数据的test表中的其他列中有非空约束的列并且没有默认值时会报错

总结:

 1.如果想让新表与旧表的结构完全一样

    使用  

 CREATE TABLE test like `user`;

2.如果想让新表与旧表的结构和数据完全一样

(1):

CREATE TABLE test like `user`;

(2)

Insert INTO test SELECT * from user;

3.尽量不使用

  create TABLE test SELECT * FROM `user`;

create TABLE test SELECT * FROM `user`where 1=2;

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值