京东云服务器推荐配置、多种配置选择,满足不同业务需求!

热门推荐

⭐ 稳定入门选择

配置:2核2G/5M

适用场景:个人站点 / 轻量应用

特点:性价比高,稳定可靠

¥19/月
立即购买
流量友好

☁️ 轻量云主机

配置:2核4G 5M

适用场景:小型业务 / 博客 / 测试环境

特点:流量友好,性能均衡

¥149/年
立即购买
高性能

💻 云服务主机

配置:4核16G 8M

适用场景:中小型服务 / 多并发场景

特点:充足内存与带宽,性能强劲

¥750/年
立即购买
新人专享

🎁 新人福利

新人访问 → 点击 → 最新活动

可获取 3000元 礼券

立即领取
数据库 / SQL 教程 / SQL 高级教程
SQL 复制表
SQL 临时表SQL 日期和时间

SQL 复制表

在本教程中,您将学习如何创建现有表的副本。

克隆或复制表

在某些情况下,您可能只想创建一个现有表的精确副本或克隆以测试或执行某些操作而又不影响原始表。

下一节将通过几个简单的步骤说明如何执行此操作。

步骤1:创建一个空表

首先使用以下语句根据原始表的定义创建一个空表。它还包括原始表中定义的列属性和索引:

CREATE TABLE new_table LIKE original_table;

步骤2:将数据插入表

现在,使用以下语句用原始表中的数据填充空表:

INSERT INTO new_table SELECT * FROM original_table;

让我们使用MySQL命令行工具克隆表。

考虑我们employees的数据库中有一个包含以下记录的表:

+--------+--------------+------------+--------+---------+
| emp_id | emp_name     | hire_date  | salary | dept_id |
+--------+--------------+------------+--------+---------+
|      1 | Ethan Hunt   | 2001-05-01 |   5000 |       4 |
|      2 | Tony Montana | 2002-07-15 |   6500 |       1 |
|      3 | Sarah Connor | 2005-10-18 |   8000 |       5 |
|      4 | Rick Deckard | 2007-01-03 |   7200 |       3 |
|      5 | Martin Blank | 2008-06-24 |   5600 |    NULL |
+--------+--------------+------------+--------+---------+

执行以下SQL语句,它将基于现有employees数据库表的定义创建一个空表employees_clone

 employees_clone  employees;

现在,执行另一个SQL语句,它将来自employee表的所有记录插入employees_clone表。 执行完此语句后,您将获得employee_clone表,该表是employee表的精确副本或副本。

 employees_clone  *  employees;

简单克隆

但是,如果只想从另一个表创建一个表而不考虑任何列属性和索引,则可以使用简单的一行语句:

CREATE TABLE new_table SELECT * FROM original_table;

以下命令创建employees表的简单副本。

 employees_dummy  *  employees;

提示:使用CREATE TABLE ... SELECT语法可以快速创建仅包含源表的结构和数据的任何表的简单副本。

SQL 临时表SQL 日期和时间
下一篇:SQL 临时表