MySQL复制表结构、表数据
1、复制表结构及数据到新表(表结构 + 数据)
CREATE TABLE 新表 SELECT * FROM 旧表;
这种方法会将old_table中所有的内容都拷贝过来,当然我们可以用delete from new_table;来删除。
不过这种方法的一个最不好的地方就是新表中没有了旧表的primary key、Extra(auto_increment)等属性,需要自己添加,而且容易搞错。
2、只复制表结构到新表(表结构)
CREATE TABLE 新表 SELECT * FROM 旧表 WHERE 1=2; // 无主键,索引等结构
或
CREATE TABLE 新表 LIKE 旧表; // 有主键,有索引等结构 (推荐)
3、复制旧表的数据到新表(数据,两个表结构一样)
INSERT INTO 新表 SELECT * FROM 旧表;
4、复制旧表的数据到新表(数据,两个表结构不一样)
INSERT INTO 新表(字段1,字段2,.......) SELECT 字段1,字段2,...... FROM 旧表;
5、可以将表1结构复制到表2(表结构)
SELECT * INTO 表2 FROM 表1 WHERE 1=2;
6、可以将表1内容全部复制到表2(表结构 + 数据)
SELECT * INTO 表2 FROM 表1;
7、 show create table 旧表;
这样会将旧表的创建命令列出。我们只需要将该命令拷贝出来,更改table的名字,就可以建立一个完全一样的表
8、mysqldump
用mysqldump将表dump出来,改名字后再导回去或者直接在命令行中运行
CREATE TABLE 方法
整表复制:
create table 新表 select * from 旧表;
结构复制:
1、create table 新表 select * from 旧表 where 1<>1;
2、CREATE TABLE 新表 LIKE 旧表;
INSERT INTO 方法
得到建表语句:
show create table 旧表;
复制数据到新表:
1、复制旧表的数据到新表(假设两个表结构一样)
INSERT INTO 新表 SELECT * FROM 旧表;
2、复制旧表的数据到新表(假设两个表结构不一样)
INSERT INTO 新表(字段1,字段2,…….) SELECT 字段1,字段2,…… FROM 旧表;
CREATE TEMPORARY TABLE 创建临时表;
版权所有: 本文系米扑博客原创、转载、摘录,或修订后发表,最后更新于 2015-07-03 09:50:59
侵权处理: 本个人博客,不盈利,若侵犯了您的作品权,请联系博主删除,莫恶意,索钱财,感谢!
转载注明: MySQL复制表结构、表数据 (米扑博客)