mysql复制表结构与表数据方法汇总

发布时间:2015-05-06编辑:脚本学堂
有关mysql复制表结构与复制表数据的方法大全,复制表结构及数据到新表,只复制表结构到新表,复制旧表的数据到新表,有关select into及mysqldump等命令的用法。

mysql复制表结构与表数据方法汇总

1、复制表结构及数据到新表
 

CREATE TABLE 新表 SELECT * FROM 旧表
 

这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来删除。
不过这种方法的一个最不好的地方就是新表中没有了旧表的primary key、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。

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出来,改名字后再导回去或者直接在命令行中运行
mysql 中如何在同一张表中复制记录

例1,复制完全相同的记录(条件是表结构中没有auto_increment,和uniq字段)
 

复制代码 代码示例:

mysql> select * from president;
+————+—————+——–+———————+——-+————+————+
| last_name  | first_name    | suffix | city                | state | birth      | death      |
+————+—————+——–+———————+——-+————+————+
| Washington | George        | NULL   | Wakefield           | VA    | 1732-02-22 | 1799-12-14 |
| Adams      | John          | NULL   | Braintree           | MA    | 1735-10-30 | 1826-07-04 |
| Jefferson  | Thomas        | NULL   | Albemarle County    | VA    | 1743-04-13 | 1826-07-04 |
| Madison    | James         | NULL   | Port Conway         | VA    | 1751-03-16 | 1836-06-28 |

mysql> desc president;
+————+————-+——+—–+———+——-+
| Field      | Type        | Null | Key | Default | Extra |
+————+————-+——+—–+———+——-+
| last_name  | varchar(15) | NO   | MUL | NULL    |       |
| first_name | varchar(15) | NO   |     | NULL    |       |
| suffix     | varchar(5)  | YES  |     | NULL    |       |
| city       | varchar(20) | NO   |     | NULL    |       |
| state      | varchar(2)  | NO   |     | NULL    |       |
| birth      | date        | NO   |     | NULL    |       |
| death      | date        | YES  |     | NULL    |       |
+————+————-+——+—–+———+——-+
 

在这种情况下要在表中复制一条Washington  George 的记录,输入命令:
 

mysql> insert into president select * from president where last_name=’Washington’;

例2:新增部分字段相同的记录
 

复制代码 代码示例:
mysql> select * from manager;
+—-+————-+——-+————-+———-+————+———————+
| id | enable_flag | types | account     | password | location   | reg_date            |
+—-+————-+——-+————-+———-+————+———————+
|  1 |           1 |     1 | abcd        | 1234567  |            | 0000-00-00 00:00:00 |
| 13 |           1 |     2 | anonymous   | 654123   | 0100000000 | 2003-06-30 17:29:04 |

其表结构:
 

复制代码 代码示例:
mysql> desc manager;
+————-+————-+——+—–+———————+—————-+
| Field       | Type        | Null | Key | Default             | Extra          |
+————-+————-+——+—–+———————+—————-+
| id          | int(4)      | NO   | PRI | NULL                | auto_increment |
| enable_flag | smallint(2) | NO   |     | 0                   |                |
| types       | smallint(2) | NO   |     | 0                   |                |
| account     | varchar(50) | NO   | UNI |                     |                |
| password    | varchar(50) | NO   |     |                     |                |
| location    | varchar(10) | NO   |     |                     |                |
| reg_date    | datetime    | NO   |     | 0000-00-00 00:00:00 |                |
————+————-+——+—–+———————+—————-+
 

若想通过新增一条和manager 表中的anonymous这条记录,其它字段内容相同,但名字不同的记录(account为test)。

则得用以下方法:
因为manager表的 id字段是auto_increment,而且account字段是具有唯一性的(UNI).所以要具体指定这两个字段的值。
 

mysql>  insert into manager select ’22′,enable_flag,types,’test’,password, location,reg_date from manager where account=’anonymous’;