在 MySQL 中使用 Insert Into Select

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 【8月更文挑战第11天】

在 MySQL 中,INSERT INTO ... SELECT 语句是一个强大的数据操作工具,用于将数据从一个表插入到另一个表中。这个语句允许在不直接指定插入值的情况下,通过从查询结果中选择数据来完成插入操作。本文将详细介绍 INSERT INTO ... SELECT 的用法,包括基本语法、示例操作、应用场景和注意事项。

1. 基本概念

1.1 INSERT INTO ... SELECT 语法

INSERT INTO ... SELECT 语句可以从一个表(或多个表)中选择数据并将其插入到目标表中。其基本语法如下:

INSERT INTO target_table (column1, column2, ...)
SELECT value1, value2, ...
FROM source_table
WHERE condition;
  • target_table:目标表,数据将插入到这个表中。
  • column1, column2, ...:目标表中的列名,必须与 SELECT 查询中的列数和顺序匹配。
  • source_table:源表,从中选择数据。
  • value1, value2, ...:从源表中选择的数据列。
  • condition:可选的条件,用于过滤要插入的数据。

2. 示例操作

2.1 基本示例

假设有两个表:employeesnew_employeesemployees 表存储了现有员工的信息,而 new_employees 表用于存储从其他来源导入的新员工数据。

创建表的示例:

CREATE TABLE employees (
    employee_id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    position VARCHAR(50)
);

CREATE TABLE new_employees (
    employee_id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    position VARCHAR(50)
);

插入数据到 new_employees 表:

INSERT INTO new_employees (name, position)
VALUES ('John Doe', 'Developer'), ('Jane Smith', 'Designer');

new_employees 中的数据插入到 employees 表:

INSERT INTO employees (name, position)
SELECT name, position
FROM new_employees;

在这个示例中,INSERT INTO employees 语句将 new_employees 表中的所有记录插入到 employees 表中。

2.2 从多个表中选择数据

可以从多个表中选择数据并将其插入到目标表中。例如,从 employees 表和 contractors 表中选择数据,并将其插入到 staff 表中:

创建表的示例:

CREATE TABLE contractors (
    contractor_id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    role VARCHAR(50)
);

CREATE TABLE staff (
    staff_id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100),
    role VARCHAR(50)
);

插入数据到 contractors 表:

INSERT INTO contractors (name, role)
VALUES ('Emily Davis', 'Consultant'), ('Michael Brown', 'Freelancer');

employeescontractors 表的数据插入到 staff 表:

INSERT INTO staff (name, role)
SELECT name, position
FROM employees
UNION ALL
SELECT name, role
FROM contractors;

在这个示例中,UNION ALL 将两个 SELECT 查询的结果合并为一个结果集,然后将其插入到 staff 表中。

3. 常见应用场景

3.1 数据迁移

INSERT INTO ... SELECT 可以用于数据迁移,例如将数据从一个数据库表迁移到另一个数据库表。迁移操作可以涉及不同的表结构、数据格式或数据库实例。

示例:

INSERT INTO new_database.employees (name, position)
SELECT name, position
FROM old_database.employees;

3.2 数据汇总

在数据分析过程中,可以使用 INSERT INTO ... SELECT 来汇总数据。例如,将来自多个表的统计信息插入到一个汇总表中:

示例:

INSERT INTO summary_report (department, total_employees)
SELECT department, COUNT(*)
FROM employees
GROUP BY department;

3.3 数据备份

INSERT INTO ... SELECT 可以用于数据备份,将数据从主表复制到备份表中:

示例:

INSERT INTO backup_employees (employee_id, name, position)
SELECT employee_id, name, position
FROM employees;

4. 注意事项

4.1 列的匹配

确保 INSERT INTO 语句中的列名与 SELECT 查询中的列顺序和数据类型匹配。如果列名和数据类型不匹配,可能会导致插入失败或数据不正确。

示例:

-- 错误的示例:列数和数据类型不匹配
INSERT INTO employees (name, position)
SELECT name, employee_id  -- 错误,`employee_id` 与目标表不匹配
FROM new_employees;

4.2 性能考虑

对于大型数据集,INSERT INTO ... SELECT 可能会影响性能。可以考虑使用批量插入、索引优化和事务控制来提高性能。

优化性能的建议:

  • 批量插入:将数据分批插入,以减少锁定和事务日志的开销。
  • 索引优化:在插入前禁用或删除索引,插入后重新创建索引。
  • 事务控制:将多个插入操作封装在一个事务中,以减少事务开销。

4.3 事务处理

在执行 INSERT INTO ... SELECT 语句时,可以使用事务控制来确保数据的一致性。例如,可以使用 START TRANSACTIONCOMMIT 来确保操作的原子性:

START TRANSACTION;

INSERT INTO employees (name, position)
SELECT name, position
FROM new_employees;

COMMIT;

如果在事务中发生错误,可以使用 ROLLBACK 来撤销操作:

START TRANSACTION;

INSERT INTO employees (name, position)
SELECT name, position
FROM new_employees;

-- 假设此处发生了错误
ROLLBACK;

5. 总结

INSERT INTO ... SELECT 是 MySQL 中一个非常实用的数据操作语句,允许将数据从一个表插入到另一个表中。通过使用 INSERT INTO ... SELECT,可以实现数据迁移、汇总和备份等操作。在实际应用中,需要确保列的匹配、考虑性能和使用事务控制。掌握这些技术可以帮助您更高效地管理 MySQL 数据库中的数据。

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
2月前
|
SQL NoSQL 关系型数据库
2024Mysql And Redis基础与进阶操作系列(5)作者——LJS[含MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页等详解步骤及常见报错问题所对应的解决方法]
MySQL DQL基本查询:select;简单、排序、分组、聚合、分组、分页、INSERT INTO SELECT / FROM查询结合精例等详解步骤及常见报错问题所对应的解决方法
|
5月前
|
存储 自然语言处理 关系型数据库
MySQL全文索引源码剖析之Insert语句执行过程
【8月更文挑战第17天】在MySQL中,处理含全文索引的`INSERT`语句涉及多步骤。首先进行语法解析确认语句结构无误;接着语义分析检查数据是否符合表结构及约束。随后存储引擎执行插入操作,若涉及全文索引则进行分词处理,并更新倒排索引结构。此外,事务管理确保了操作的完整性和一致性。通过示例创建含全文索引的表并插入数据,可见MySQL如何高效地处理此类操作,有助于优化数据库性能和提升全文搜索效果。
|
5月前
|
关系型数据库 MySQL
解决MySQL insert出现Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘xxx‘ at row 1
解决MySQL insert出现Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘xxx‘ at row 1
451 2
|
6月前
|
存储 关系型数据库 文件存储
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
面试题MySQL问题之简单的SELECT操作在MVCC下加锁如何解决
62 2
|
6月前
|
关系型数据库 MySQL 索引
MySQL之优化SELECT语句
以上只是一些基本的优化策略,具体的优化方案还需要根据实际的业务需求和数据情况来定制。
64 0
|
7月前
|
关系型数据库 MySQL 数据库
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
MySQL SELECT查询实战:练习题精选,提升你的数据库查询技能
|
7天前
|
关系型数据库 MySQL 数据库连接
数据库连接工具连接mysql提示:“Host ‘172.23.0.1‘ is not allowed to connect to this MySQL server“
docker-compose部署mysql8服务后,连接时提示不允许连接问题解决
|
11天前
|
缓存 关系型数据库 MySQL
【深入了解MySQL】优化查询性能与数据库设计的深度总结
本文详细介绍了MySQL查询优化和数据库设计技巧,涵盖基础优化、高级技巧及性能监控。
112 0
|
1月前
|
存储 Oracle 关系型数据库
数据库传奇:MySQL创世之父的两千金My、Maria
《数据库传奇:MySQL创世之父的两千金My、Maria》介绍了MySQL的发展历程及其分支MariaDB。MySQL由Michael Widenius等人于1994年创建,现归Oracle所有,广泛应用于阿里巴巴、腾讯等企业。2009年,Widenius因担心Oracle收购影响MySQL的开源性,创建了MariaDB,提供额外功能和改进。维基百科、Google等已逐步替换为MariaDB,以确保更好的性能和社区支持。掌握MariaDB作为备用方案,对未来发展至关重要。
64 3
|
1月前
|
安全 关系型数据库 MySQL
MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!
《MySQL崩溃保险箱:探秘Redo/Undo日志确保数据库安全无忧!》介绍了MySQL中的三种关键日志:二进制日志(Binary Log)、重做日志(Redo Log)和撤销日志(Undo Log)。这些日志确保了数据库的ACID特性,即原子性、一致性、隔离性和持久性。Redo Log记录数据页的物理修改,保证事务持久性;Undo Log记录事务的逆操作,支持回滚和多版本并发控制(MVCC)。文章还详细对比了InnoDB和MyISAM存储引擎在事务支持、锁定机制、并发性等方面的差异,强调了InnoDB在高并发和事务处理中的优势。通过这些机制,MySQL能够在事务执行、崩溃和恢复过程中保持
86 3

热门文章

最新文章