日期:2014-05-16 浏览次数:20459 次
实验六 多表查询
【实验目的】
1. 掌握等值连接和非等值连接
2. 掌握自身连接(同一个表之间连接)
3. 掌握外连接
4. 掌握复合条件连接
【实验内容】
1. 基本命令:
select <目标列>
from <表1,表2>[,<表3>[,<...>]]
where <条件>
功能:从表1和表2中查询满足条件的目标列。
2. 实验内容
【例1】查询选修了3号课程的学生学号和姓名
select student.sno,sname from student,sc where student.sno = sc.sno and cno = '3'
备注:表1和表2笛卡尔积,是连接的第一步,是第一个表的每一行与第二个表的每一行组成一次连接(元组相连)。表1和表2的笛卡尔积,有M(M=表1行数*表2行数)行,N(N=表1列数+表2列数)列。
笛卡尔积的每一行不一定有意义。例如学生表student和选课表sc的笛卡尔积20行中只有5行有意义。需要我们做筛选条件,就是表1的某一列=表二的某一列。例如student.sno = sc.sno
【例2】查询所有课程的先修课课程号,课程名和学分
解释:题目需要查询课程信息,附加先修课信息。
--查询每个课程的先修课学分(课程号,课程名,课程学分,先修课名和先修课学分) select 课程.cno,课程.cname,课程.ccredit,课程.cpno,先修课程.Cname,先修课程.ccredit from Course 课程,Course 先修课程 where 课程.Cpno = 先修课程.Cno
【例3】查询全体学生的选修课程情况
解释:外连接能够实现表1与表2具有联系的元组显示的同时,可以显示某个表全部元组(左连接全部显示左边表,右连接全部显示右边表)。
比较:select student.*,cno,grade
from student,sc
where student.sno = sc.sno
本命令只能够查询具有选修课程的学生,没有显示全部学生。(即没有选修课的学生,在结果中没有显示出来)
比较命令:
-- 比较如下查询,查询学生选修情况(只列出具有选课的学生) select student.*,cno,grade from student,sc where student.sno = sc.sno --查询全部学生的选修课程情况,没有选修课程的也要显示出来。 select student.*,cno,grade from student left join sc on student.sno = sc.sno
查询效果:
【例4】(复合条件查询)
【实验总结】
多表查询,实现过个表的查询。