数据库联接的知识点,易错点

时间:2021-09-25 16:23:31

联接分为:

left join(左联接): 返回包括左表中的所有记录和右表中联结字段相等的记录。3

right join(右联接): 返回包括右表中的所有记录和左表中联结字段相等的记录。4

inner join(等值连接): 只返回两个表中联结字段相等的行。

我们主要使用左联接。

例子: 

1.在学院表、专业表中,查询开设4年制专业的所有学院及其下设专业,

不符合条件、未设专业的学院(部门)亦一并列出

SELECT

D.Name AS Department

    ,M.Name AS Major

FROM

    tb_Department AS D

LEFT JOIN tb_Major AS M ON M.DepartmentNo=D.No

WHERE

M.Length=4;

例题中的错误是左联接中保留的外部行将被WHERE子句删除。

修改成:

SELECT

    D.Name AS Department

    ,M.Name AS Major

FROM

    tb_Department AS D

LEFT JOIN tb_Major AS M ON M.DepartmentNo=D.No AND M.Length=4;

 

2.在学院(部门)表、专业表、班级表中,查询各学院(部门)下设的所有班级,若某学院(部门)无班级,亦一并列出

SELECT

    D.Name AS Department

,RIGHT(CONVERT(VARCHAR,C.Year),2)+M.ShortName+ISNULL(C.AdministrationClass,'') AS Class

FROM

tb_Department AS D

LEFT JOIN tb_Major AS M ON D.No=M.DepartmentNo

JOIN tb_Class AS C ON M.No=C.MajorNo;

 

例题中的错误是左联接能为左侧表保留不匹配的外部行,但外部行中对应右侧表的属性取值均为NULL,而这些NULL值在随后的内联接中永远找不到匹配,故这些外部行最终无法保留。

修改为:

SELECT

    D.Name AS Department

,RIGHT(CONVERT(VARCHAR,C.Year),2)+M.ShortName+ISNULL(C.AdministrationClass,'') AS Class

FROM

tb_Department AS D

LEFT JOIN

(tb_Major AS M

JOIN tb_Class AS C ON M.No=C.MajorNo) ON D.No=M.DepartmentNo;