MySQL可以根据查询到的记录集插入到指定的表中其例子为:
首先阐述三张表的结构:
s(sno,sname.sex,age,dept) //学生信息表
c(cno,cname,tname) //课程信息表
sc(sno,cno,grade) //课程选修信息表那么现在就是问题是:
将一门课的成绩大于等于80分学生的学号、姓名和系名插入到一个已存在(要建立)基本表stu(sno,sname,dept)中
stu表已存在 数据库 Schema为:
<span style="font-size:18px;color:#FF0000;">drop table if EXISTS stu ; create table stu ( sno int(4) unique , sname varchar(20), dept varchar(10) );</span>
那么现在将结果的sql语句写出来:
<span style="font-size:18px;color:#FF0000;">insert into stu (sno,sname,dept) select sno ,sname , dept from s where s.sno in (select sc.sno from sc where sc.grade >= 80 ); </span>
接下来是上面的sql语句的语法规则 :
INSERT INTO 表名1(字段列表1) SELECT 字段列表2 FROM 表名2 WHERE 条件表达式; 表名1:表示记录插入到哪个表中。字段列表1:表示为哪些字段赋值。字段列表2:表示从表中查询出哪些字段的数据。表名2:表示记录是从哪个表中查询出来的。条件表达式:表示设置SELECT语句的查询条件。
将[表名2]中查询出来的记录插入到[表名1]中以后,[表名2]中仍然保存着原来的记录。
提示:使用这种方法时,必须保证[字段列表1]和[字段列表2]中的字段个数是一样的,同时,也必须保证每个对应的字段的数据类型是一样的。如果数据类型不一样,数据库 系统 会报错。然后,阻止INSERT语句向下执行。
查看更多关于mysql可以根据查询结果插入到指定的表中 - mysql数的详细内容...
声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did5276