Mysql复制表结构、表数据的方法
本文给大家分享了好几种复制表结构、表数据的示例介绍,具体详情请看下文吧。
1、复制表结构及数据到新表
CREATETABLE新表SELECT*FROM旧表
这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用deletefromnewtable;来删除。
不过这种方法的一个最不好的地方就是新表中没有了旧表的primarykey、Extra(auto_increment)等属性。需要自己用"alter"添加,而且容易搞错。
2、只复制表结构到新表
CREATETABLE新表SELECT*FROM旧表WHERE1=2
或CREATETABLE新表LIKE旧表
3、复制旧表的数据到新表(假设两个表结构一样)
INSERTINTO新表SELECT*FROM旧表
4、复制旧表的数据到新表(假设两个表结构不一样)
INSERTINTO新表(字段1,字段2,.......)SELECT字段1,字段2,......FROM旧表
5、可以将表1结构复制到表2
SELECT*INTO表2FROM表1WHERE1=2
6、可以将表1内容全部复制到表2
SELECT*INTO表2FROM表1
7、showcreatetable旧表;
这样会将旧表的创建命令列出。我们只需要将该命令拷贝出来,更改table的名字,就可以建立一个完全一样的表
8、mysqldump
用mysqldump将表dump出来,改名字后再导回去或者直接在命令行中运行
9、复制旧数据库到新数据库(复制全部表结构并且复制全部表数据)
#mysql-uroot-ppassword
>CREATEDATABASEnew_db;
#mysqldumpold_db-uroot-ppassword--skip-extended-insert--add-drop-table|mysqlnew_db-uroot-ppassword
10、表不在同一数据库中(如,db1table1,db2table2)
sql:insertintodb1.table1select*fromdb2.table2(完全复制)
insertintodb1.table1selectdistinct*fromdb2.table2(不复制重复纪录)
insertintotdb1.able1selecttop5*fromdb2.table2(前五条纪录)以上内容就是本文的全部叙述,希望大家喜欢。