Home > Database > Mysql Tutorial > mysql可以根据查询结果插入到指定的表中_MySQL

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

WBOY
Release: 2016-06-01 13:01:41
Original
1253 people have browsed it

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>
Copy after login


那么现在将结果的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>
Copy after login

接下来是上面的sql语句的语法规则 :

INSERT INTO 表名1(字段列表1)
       SELECT 字段列表2 FROM 表名2 WHERE 条件表达式;
Copy after login
表名1:表示记录插入到哪个表中。字段列表1:表示为哪些字段赋值。字段列表2:表示从表中查询出哪些字段的数据。表名2:表示记录是从哪个表中查询出来的。条件表达式:表示设置SELECT语句的查询条件。

 

将“表名2”中查询出来的记录插入到“表名1”中以后,“表名2”中仍然保存着原来的记录。

提示:

使用这种方法时,必须保证“字段列表1”和“字段列表2”中的字段个数是一样的,同时,也必须保证每个对应的字段的数据类型是一样的。如果数据类型不一样,数据库系统会报错。然后,阻止INSERT语句向下执行。


Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template