文章永久连接:https://tech.souyunku.com/?p=4927
有时候我们可能需要将一张表完全的复制到另一张表,包括表的结构,索引,默认值等
MySQL 有没有这样的命令能够完成这样的任务呢?
有,也没有
说没有,是因为没有直接哪个命令能做这件事
说有,是因为可以用一序列之前学的命令完成这项任务
复制表
我们也不多介绍了,直接说要如何做吧
1、 使用 SHOW CREATE TABLE
命令获取创建数据表 ( CREATE TABLE
) 语句,该语句包含了原数据表的结构,索引等
2、 复制 1
中的 SQL 语句,修改数据表名,并执行 SQL 语句,完整的克隆出一个数据表结构一模一样的表
3、 如果需要复制表的内容,可以使用 INSERT INTO ... SELECT
语句来实现
演示
1、 运行下面的 SQL 语句创建测试数据
DROP TABLE IF EXISTS `tbl_language`;
CREATE TABLE IF NOT EXISTS `tbl_language`(
`id` INT UNSIGNED AUTO_INCREMENT,
`name` VARCHAR(64) NOT NULL,
`url` VARCHAR(128) NOT NULL,
`founded_at` DATE,
PRIMARY KEY ( `id` )
)ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
INSERT INTO `tbl_language` VALUES
(1,'Python','https://tech.souyunku.com','1991-2-20'),
(2,'PHP','http://www.php.net','1994-1-1'),
(3,'Ruby','https://www.ruby-lang.org/','1996-12-25');
2、 使用 SHOW CREATE TABLE tbl_language\G;
命令查看创建表 tbl_language
的语法
MariaDB [souyunku]> SHOW CREATE TABLE tbl_language\G;
*********************** 1. row ***********************
Table: tbl_language
Create Table: CREATE TABLE `tbl_language` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(64) NOT NULL,
`url` varchar(128) NOT NULL,
`founded_at` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4
1 row in set (0.00 sec)
会显示两个字段,一个字段是当前的表名,另一个字段是创建表的语句
3、 复制上面的语句,修改表名为 tbl_lang
并运行修改后的 SQL 语句
CREATE TABLE `tbl_lang` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(64) NOT NULL,
`url` varchar(128) NOT NULL,
`founded_at` date DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
4、 如果要复制数据,则可以使用下面的语句
INSERT INTO tbl\_lang SELECT \* FROM tbl\_language;
5、 执行 SELECT * FROM tbl_lang;
查看下表中的数据
MariaDB [souyunku]> SELECT * FROM tbl_lang;
+----+--------+----------------------------+------------+
| id | name | url | founded_at |
+----+--------+----------------------------+------------+
| 1 | Python | https://tech.souyunku.com | 1991-02-20 |
| 2 | PHP | http://www.php.net | 1994-01-01 |
| 3 | Ruby | https://www.ruby-lang.org/ | 1996-12-25 |
+----+--------+----------------------------+------------+
3 rows in set (0.01 sec)
真的,一模一样
干货推荐
附录:MySQL 教程:系列文章
- 一、MySQLMariaDB 基础教程
- 二、MySQL 简介
- 三、MySQL MariaDB 安装
- 四、MySQL 管理
- 五、MySQL 日常管理
- 六、MySQL PHP 语法
- 七、MySQL 创建连接
- 八、MySQL 获取数据库列表
- 九、MySQL 创建数据库
- 十、MySQL 删除数据库
- 十一、MySQL 选择数据库
- 十二、MySQL 数据类型
- 十三、MySQL 列出数据表
- 十四、MySQL 创建数据表
- 十五、MySQL 删除表
- 十六、MySQL 插入数据
- 十七、MySQL 获取插入数据的 ID
- 十八、MySQL SELECT FROM 查询数据
- 十九、MySQL WHERE 子句有条件的查询数据
- 二十、MySQL UPDATE 更新数据
- 二十一、MySQL DELETE FROM 语句删除数据
- 二十二、MySQL 返回删改查受影响的行数
- 二十三、MySQL LIKE 子句模糊查询数据
- 二十四、MySQL UNION 操作符查询多张表
- 二十五、MySQL ORDER BY 排序
- 二十六、MySQL GROUP BY 分组查询数据
- 二十七、MySQL JOIN 进行多表查询
- 二十八、MySQL NULL 值处理
- 二十九、MySQL REGEXP 子句正则表达式查询
- 三十、MySQL 数据库事务
- 三十一、MySQL ALTER 命令
- 三十二、MySQL 索引
- 三十三、CREATE TEMPORARY TABLE 创建临时表
- 三十四、MySQL DROP TABLE 删除临时表
- 【当前读到】三十五、MySQL INSERT INTO SELECT 复制表
- 三十六、MySQL 获取服务器元数据
- 三十七、MySQL 自增序列 AUTO_INCREMENT
- 三十八、MySQL 处理重复数据
- 三十九、MySQL 安全及防止 SQL 注入攻击
- 四十、MySQL 导出数据
- 四十一、MySQL 导入数据