学习目标:
SELECT — 连接查询
连接查询:同时涉及多个表的查询
用来连接两个表的条件成为连接条件或连接谓词
sql中连接查询的主要类型:
- (1)交叉连接(广义笛卡尔积)
- (2)等值连接
- (3)自身连接
- (4)复合条件连接
- (5)内连接
- (6)外连接
学习内容:
sql中连接查询的主要类型:
(1)交叉连接(广义笛卡尔积)
不带谓词的连接,很少使用
SELECT student.*,sc.* FROM student,sc
SELECT student.*,sc.* FROM student cross join sc
很多都是无意义的,所以很少使用
(2)等值连接
连接运算符为=的连接
--查询每个学生及其选修课程的情况
select student.*,sc.* from student,sc where student.sno=sc.sno;
--查询计算机专业学生的学号,姓名,专业,选修的课程号,课程名,及成绩
select sc.sno,sname,sdept,sc.cno,cname,grade
from student,sc,course
where student.sno=sc.sno and course.cno=sc.cno
and sdept='CS';
(3)自身连接
表示方法:
- 需要给表起别名以示区别
- 由于所有属性名都是同名属性,因此必须使用别名前缀
--查询每一门课程的直接先修课的课程名
select a1.cname,a2.cname from course a1,course a2 where a1.cpno=a2.cno;
--查询每一门课的间接先修课的课程号(即先修课的先修课)
select a1.cno,a2.cno from course a1,course a2 where a1.cpno=a2.cpno;
--查询同时选修2号课程和3号课程的学生学号
select a1.sno from sc a1,sc a2 where a1.sno=a2.sno and a1.cno=2 and a2.cno=3;
- (4)复合条件连接
where子句包含多个连接条件时,称为符合条件连接
分类:
两表按多个属性连接
自身按多个属性连接
多表连接
--查询选修1号可且成绩在90分以上的学生姓名,性别及所在系
select sname,ssex,sdept from student,sc
where student.Sno=sc.Sno /*连接谓词*/
and cno=1
and grade>90;
--查询每个学生的学号、姓名、选修的课程名即成绩
select student.sno,sname,cname,grade from student,sc,course
where student.sno=sc.sno
and sc.cno=course.cno;
- (5)内连接
inner join 或者 join
内连接实际就是等值连接,他使用“=、>、<、<>”等运算符根据每个表共有的列的值匹配两个表中的行查询语句
--查询所有学生信息及其选修课程情况
select student.*,sc.* from student join sc
on student.sno=sc.sno;
- (6)外连接
左连接(left join)或左外连接(left outer join)
右连接(right join)或右外连接(right outer join)
全连接(full join)或全外连接(full outer join)
--所有学生的全部信息及其选课记录
select student.*,sc.* from student left join sc
on student.sno=sc.sno;
--所有学生的选课记录及对应课程信息
select sc.*,course.* from sc right join course
on sc.cno=course.cno;
select sc.*,course.* from sc full join course
on sc.cno=course.cno;
//返回左表和右表中的所有行,当某行在另一表中无匹配行时,则返回空值