本文主要是介绍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数据库中,将一张表的数据插入到另一张表的各种情况的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!