MySQL中INSERT+SELECT的使用方式

 更新时间:2024年10月23日 15:51:55   作者:JMzz  
MySQL的INSERT INTO SELECT FROM语句允许用户通过一条SQL语句实现从一个或多个表中查询数据并将结果插入到另一个表中,这种方式特别适用于需要将数据从一张表迁移到另一张表,或者基于多表查询结果创建新表的场景

MySQL中INSERT+SELECT的使用

使用场景

通过一条sql语句实现从多个表中组合字段然后插入到另外的一个新表中。

1.两表之间

从一张表中查出字段的值插入到另一张表中对应的字段

INSERT INTO tab1(field1,field2) SELECT field1,field2 FROM tab2;

2.三表之间

从两张表中查出字段的值插入到另一张表中对应的字段

INSERT INTO tab1 (field1, field2) 
SELECT * 
FROM
  (SELECT 
    tab2.field1, tab3.field2 
  FROM tab2 
  JOIN tab3 
    ON tab2.field = tab3.filed) AS tab ;

3.多表之间

从多张表中查出字段的值插入到另一张表中对应的字段

INSERT INTO tab1 (field1, field2, field3, ... ) 
SELECT * 
FROM
  (SELECT 
    tab2.field1, tab3.field2, tab4.field3,  ...
  FROM tab2 
  JOIN tab3 
    ON tab2.field = tab3.filed
  JOIN tab4 
    ON tab2.field = tab4.filed  
    ...
    ) AS tab ;

通过join查询将分别来自表tab2和表tab3的字段进行了组合,然后再通过select嵌套查询插入到表tab1中,如果需要不止2个表,那么可以多个join的形式来组合字段。

需要注意的是嵌套查询部分最后一定要有设置表别名。

这种方式要求目标表必须存在。

还有一种不需要目标表的存在,就是SELECT INTO

MySQL中SELECT INTO FROM的使用

作为另一种复制表数据的手段,其得到的结果与上述的insert into select是一样。

不过select into不要求目标表存在,目标表会在查询过程中自动创建。

select[column1,column2...] into [目标表名] from [原始表名]

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL用户权限验证与管理方法详解

    MySQL用户权限验证与管理方法详解

    这篇文章主要介绍了MySQL用户权限验证与管理方法,结合实例形式详细分析了mysql针对用户权限的验证、查看、收回、修改等各种常用操作技巧,需要的朋友可以参考下
    2018-04-04
  • MySQL的几种安装方式及配置问题小结

    MySQL的几种安装方式及配置问题小结

    这篇文章主要介绍了MySQL的几种安装方式及配置,然后在文章底部给大家介绍了安装过程中的问题总结,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-07-07
  • MySQL5.7中的JSON基本操作指南

    MySQL5.7中的JSON基本操作指南

    这篇文章主要给大家介绍了关于MySQL5.7中JSON的基本操作,文中通过示例代码介绍的非常详细,对大家学习或者使用Mysql具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • MySQL对limit查询语句的优化方法

    MySQL对limit查询语句的优化方法

    这篇文章主要介绍了MySQL对limit查询语句的优化方法,分别讲解了offset参数比较小和offset参数比较大的时候,如何优化查询语句,需要的朋友可以参考下
    2014-07-07
  • MySQL中MTR的概念

    MySQL中MTR的概念

    这篇文章主要介绍了MySQL中MTR的概念,帮助大家更好的理解和使用MySQL数据库,感兴趣的朋友可以了解下
    2020-11-11
  • 详解MySQL中的视图

    详解MySQL中的视图

    视图是一个虚拟表,非真实存在,其本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用视图名称即可获取结果集,并可以将其当作表来使用,这篇文章主要介绍了MySQL的视图,需要的朋友可以参考下
    2022-12-12
  • mysql的union和union all用法详解

    mysql的union和union all用法详解

    union 和 union all 的区别是,union 会自动压缩多个结果集合中的重复结果,而 union all 则将所有的结果全部显示出来,不管是不是重复,本文给大家介绍mysql的union和union all用法,感兴趣的朋友一起看看吧
    2023-08-08
  • mysql实现设置定时任务的方法分析

    mysql实现设置定时任务的方法分析

    这篇文章主要介绍了mysql实现设置定时任务的方法,结合实例形式分析了mysql定时任务相关的事件计划设置与存储过程使用等操作技巧,需要的朋友可以参考下
    2019-10-10
  • Windows11下MySQL 8.0.29 安装配置方法图文教程

    Windows11下MySQL 8.0.29 安装配置方法图文教程

    这篇文章主要为大家详细介绍了Windows11下MySQL 8.0.29 安装配置方法图文教程,文中安装步骤介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-07-07
  • 详解MySQL实时同步到Oracle解决方案

    详解MySQL实时同步到Oracle解决方案

    这篇文章主要介绍了详解MySQL实时同步到Oracle解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03

最新评论