左外连接
:LEFT JOIN 关键字会从左表 (表1) 那里返回所有的行,即使在右表 (表2) 中没有匹配的行


LEFT JOIN 语法:





SELECT 列名FROM 表1LEFT JOIN 表2ON 表1.列名=表2.列名

学生表Student

SQL 多表查询-外连接_java

成绩表SC

SQL 多表查询-外连接_java_02


左连接(LEFT JOIN)实例

查询学生的成绩记录,显示学生编号、学生姓名、课程、成绩。

如果学生没有成绩记录的也列出姓名






select t1.SId 学生编号,t1.Sname 学生姓名,t2.CId 课程,t2.score 成绩from Student t1 left join SC t2on t1.SId=t2.SId

输出结果

结果显示可知:

LEFT JOIN 关键字会从左表 (Student) 那里返回所有的行,即使在右表 (Sc) 中没有匹配的行。



右外连接RIGHT JOIN 关键字会右表 (表2) 那里返回所有的行,即使在左表 (表1) 中没有匹配的行。


RIGHT JOIN 语法:





SELECT 列名FROM 表1RIGHT JOIN 表2ON 表1.列名=表2.列名


老师表Teacher

课程表Course

SQL 多表查询-外连接_java_03


右连接(RIGHT JOIN)实例

查询所有课程以及对应的所有老师,如果有的话






SELECT t1.*,t2.Cid,t2.CnameFROM Teacher t1 RIGHT JOIN Course t2on t1.TId=t2.TId



输出结果:

SQL 多表查询-外连接_java_04

结果显示可知:

RIGHT JOIN 关键字会从右表 (Course) 那里返回所有的行,即使在左表 (Teacher) 中没有匹配的行。