如果我们需要完全的复制mysql的数据表,包括表的结构,索引,默认值等。 如果仅仅使用create table ... select 命令,是无法实现的。
本章节将为大家介绍如何完整的复制mysql数据表,步骤如下:
尝试以下实例来复制表 w3cschool_tbl 。
步骤一:
获取数据表的完整结构。
mysql> show create table w3cschool_tbl \g; *************************** 1. row *************************** table: w3cschool_tbl create table: create table `w3cschool_tbl` ( `w3cschool_id` int(11) not null auto_increment, `w3cschool_title` varchar(100) not null default '', `w3cschool_author` varchar(40) not null default '', `submission_date` date default null, primary key (`w3cschool_id`), unique key `author_index` (`w3cschool_author`) ) engine=innodb 1 row in set (0.00 sec) error: no query specified
步骤二:
修改sql语句的数据表名,并执行sql语句。
mysql> create table `clone_tbl` ( -> `w3cschool_id` int(11) not null auto_increment, -> `w3cschool_title` varchar(100) not null default '', -> `w3cschool_author` varchar(40) not null default '', -> `submission_date` date default null, -> primary key (`w3cschool_id`), -> unique key `author_index` (`w3cschool_author`) -> ) engine=innodb; query ok, 0 rows affected (1.80 sec)
步骤三:
执行完第二步骤后,你将在数据库中创建新的克隆表 clone_tbl。 如果你想拷贝数据表的数据你可以使用 insert into... select 语句来实现。
mysql> insert into clone_tbl (w3cschool_id, -> w3cschool_title, -> w3cschool_author, -> submission_date) -> select w3cschool_id,w3cschool_title, -> w3cschool_author,submission_date -> from w3cschool_tbl; query ok, 3 rows affected (0.07 sec) records: 3 duplicates: 0 warnings: 0
执行以上步骤后,你将完整的复制表,包括表结构及表数据。