码迷,mamicode.com
首页 > 数据库 > 详细

mysql 可以根据查询结果插入到指定的表中

时间:2015-03-31 22:31:11      阅读:160      评论:0      收藏:0      [点我收藏+]

标签:mysql根据查询的结果将查询的结果插入


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://blog.csdn.net/u013803262/article/details/44783349

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!