mysql 可以根据查询结果插入到指定的表中
2015-03-31 18:41
369 查看
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 wheres.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查询结果按指定顺序排序
- MySq之一条mysql语句来更新(插入)查询结果
- mysql怎么指定查询一张表的查询结果,如最后5行记录和最前5行记录
- MySQL将查询结果插入到数据表中
- mysql根据查询结果,创建表
- mysql基于查询结果批量插入和更新
- 记录一下MYSQL把两表查询结果插入新表
- mysql中如何将查询结果的多个记录中的指定字段放到一个二维数组中,以及在in子句中使用数组
- MySql查询结果按照指定顺序排序
- MySql查询结果按照指定顺序排序
- mysql将查询结果插入新表
- 把一个select查询结果插入到一个表(可选指定字段和值实例)
- mysql根据时间戳查询指定日期内数据
- mysql根据查询结果创建表
- mysql 将查询结果插入一张表
- mysql创建临时表,将查询结果插入已有表中
- 把一个select查询结果插入到一个表(可选指定字段和值实例)
- mysql将查询结果插入新表
- MySql查询结果按照指定顺序排序
- MySQL查询结果复制到新表(更新、插入)