Heim > Datenbank > MySQL-Tutorial > mysql可以根据查询结果插入到指定的表中_MySQL

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

WBOY
Freigeben: 2016-06-01 13:01:41
Original
1251 Leute haben es durchsucht

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>
Nach dem Login kopieren


那么现在将结果的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>
Nach dem Login kopieren

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

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

 

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

提示:

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


Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage