学习目标:

SELECT — 连接查询
连接查询:同时涉及多个表的查询
用来连接两个表的条件成为连接条件或连接谓词
sql中连接查询的主要类型:

  • (1)交叉连接(广义笛卡尔积)
  • (2)等值连接
  • (3)自身连接
  • (4)复合条件连接
  • (5)内连接
  • (6)外连接

学习内容:

sql中连接查询的主要类型:

(1)交叉连接(广义笛卡尔积)
不带谓词的连接,很少使用

SELECT student.*,sc.* FROM student,sc
SELECT student.*,sc.* FROM student cross join sc

sql server 查询向下级联查询 sql server 关联查询_sqlserver


很多都是无意义的,所以很少使用

(2)等值连接
连接运算符为=的连接

--查询每个学生及其选修课程的情况
select student.*,sc.* from student,sc where student.sno=sc.sno;

sql server 查询向下级联查询 sql server 关联查询_sql server 查询向下级联查询_02

--查询计算机专业学生的学号,姓名,专业,选修的课程号,课程名,及成绩
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';

sql server 查询向下级联查询 sql server 关联查询_sqlserver_03

(3)自身连接
表示方法:

  • 需要给表起别名以示区别
  • 由于所有属性名都是同名属性,因此必须使用别名前缀
--查询每一门课程的直接先修课的课程名
select a1.cname,a2.cname from course a1,course a2 where a1.cpno=a2.cno;

sql server 查询向下级联查询 sql server 关联查询_外连接_04

--查询每一门课的间接先修课的课程号(即先修课的先修课)
select a1.cno,a2.cno from course a1,course a2 where a1.cpno=a2.cpno;

sql server 查询向下级联查询 sql server 关联查询_外连接_05

--查询同时选修2号课程和3号课程的学生学号
select a1.sno from sc a1,sc a2 where a1.sno=a2.sno and a1.cno=2 and a2.cno=3;

sql server 查询向下级联查询 sql server 关联查询_外连接_06

  • (4)复合条件连接

where子句包含多个连接条件时,称为符合条件连接
分类:
两表按多个属性连接
自身按多个属性连接
多表连接

--查询选修1号可且成绩在90分以上的学生姓名,性别及所在系
select sname,ssex,sdept from student,sc
where student.Sno=sc.Sno /*连接谓词*/
	and cno=1
	and grade>90;

sql server 查询向下级联查询 sql server 关联查询_数据库_07

--查询每个学生的学号、姓名、选修的课程名即成绩
select student.sno,sname,cname,grade from student,sc,course
where student.sno=sc.sno
	and sc.cno=course.cno;

sql server 查询向下级联查询 sql server 关联查询_sql server 查询向下级联查询_08

  • (5)内连接

inner join 或者 join
内连接实际就是等值连接,他使用“=、>、<、<>”等运算符根据每个表共有的列的值匹配两个表中的行查询语句

--查询所有学生信息及其选修课程情况
select student.*,sc.* from student join sc
on student.sno=sc.sno;

sql server 查询向下级联查询 sql server 关联查询_sqlserver_09

  • (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;

sql server 查询向下级联查询 sql server 关联查询_数据库_10

--所有学生的选课记录及对应课程信息
select sc.*,course.* from sc right join course
on sc.cno=course.cno;

sql server 查询向下级联查询 sql server 关联查询_sql server 查询向下级联查询_11

select sc.*,course.* from sc full join course
on sc.cno=course.cno;
//返回左表和右表中的所有行,当某行在另一表中无匹配行时,则返回空值

sql server 查询向下级联查询 sql server 关联查询_sqlserver_12