mysql复制表结构与表数据方法汇总
1、复制表结构及数据到新表
这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete from newtable;来删除。
不过这种方法的一个最不好的地方就是新表中没有了旧表的primary key、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。
2、只复制表结构到新表
3、复制旧表的数据到新表(假设两个表结构一样)
4、复制旧表的数据到新表(假设两个表结构不一样)
5、可以将表1结构复制到表2
6、可以将表1内容全部复制到表2
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 的记录,输入命令:
例2:新增部分字段相同的记录
其表结构:
若想通过新增一条和manager 表中的anonymous这条记录,其它字段内容相同,但名字不同的记录(account为test)。
则得用以下方法:
因为manager表的 id字段是auto_increment,而且account字段是具有唯一性的(UNI).所以要具体指定这两个字段的值。