MySQL数据库中,将一张表的数据插入到另一张表的各种情况

2024-06-21 14:32

本文主要是介绍MySQL数据库中,将一张表的数据插入到另一张表的各种情况,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近研究了下在MySQL数据库中,将一张表的数据插入到另一张表的各种情况,做了如下笔记:
前提条件:我在MySQL里面创建了mydb数据库,该数据库里面创建了student表(记为a表)、stu表(记为b表)、t_student 表(记为c表),笔记中的示例是在MySQL命令行完成的。

1.a、b表的表结构一样时 ,把a表的全部数据插入b表.
sql: insert into b (select * from a);
示例:a、b表的结构如下,
这里写图片描述
这里写图片描述
插入前a、b表的数据内容:
这里写图片描述
插入后b表的数据内容:
这里写图片描述
*这里的子查询没有加()没报错,但为了规范建议给子查询加上().

2.a、b表的表结构一样时 ,把a表的部分数据插入b表.
sql: insert into b(column1, column2, …) (select column1, column2, … from a);
示例:a、b表的结构如1中所示,插入前a、b表的数据内容:
这里写图片描述
只插入姓名和年龄字段:
这里写图片描述
这里报错了,报student_no字段没有给默认值,因为student_no字段定义不能为null。所以,插入部分数据时不能为null的字段必须插入数据。
不能为null的字段都插入数据,结果如下:
这里写图片描述

3.a、b表的表结构一样时,只需要插入b表中不存在的数据(这里是插入所有字段,也可以插入指定字段)
sql:insert into b (select * from a where not exists
(select * from b where b.比较字段 = a.比较字段));
示例:a、b表的结构如1中所示,插入前a、b表的数据内容:
这里写图片描述
插入后b表的数据内容:
这里写图片描述

4.当两张表的结构不一样时,需要指定列名并且对应的数据类型要一样
a、c表的表结构如下:
这里写图片描述
示例:把a表的数据全部插入c表
这里写图片描述

5.多张表的情况,以3张表为例,emp员工表、dept部门表、emp_info员工信息表
3张的表的表结构如下:
这里写图片描述
多表情况下,需要查询的字段join起来,再用select from查询.注意:这里的join后一定要指定别名,否则报错.
sql:insert into a(column1, column2, …)
(select * from (select column1, column2 from b join c) as tb)
示例:把emp表和dept表的信息插入到员工信息表emp_info中
插入前,3张的表的数据如下:
这里写图片描述
插入后,员工信息表的数据如下:
这里写图片描述

总结,主要注意对应字段的字段名称和字段数据类型,字段名称不一样时要明确指定要插入数据的字段名称;数据类型不一样时,如果基本类型一样(比如tinyint和int),数据范围没超的话可以,如果超出数据类型能表示的范围或者基本数据类型不一样就会报错,需要先转换数据类型。

这篇关于MySQL数据库中,将一张表的数据插入到另一张表的各种情况的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1081474

相关文章

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Mac电脑如何通过 IntelliJ IDEA 远程连接 MySQL

《Mac电脑如何通过IntelliJIDEA远程连接MySQL》本文详解Mac通过IntelliJIDEA远程连接MySQL的步骤,本文通过图文并茂的形式给大家介绍的非常详细,感兴趣的朋友跟... 目录MAC电脑通过 IntelliJ IDEA 远程连接 mysql 的详细教程一、前缀条件确认二、打开 ID