左外连接:LEFT JOIN 关键字会从左表 (表1) 那里返回所有的行,即使在右表 (表2) 中没有匹配的行
LEFT JOIN 语法:
SELECT 列名FROM 表1LEFT JOIN 表2ON 表1.列名=表2.列名
学生表Student
成绩表SC
左连接(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
右连接(RIGHT JOIN)实例
查询所有课程以及对应的所有老师,如果有的话
SELECT t1.*,t2.Cid,t2.CnameFROM Teacher t1 RIGHT JOIN Course t2on t1.TId=t2.TId
输出结果:
结果显示可知:
RIGHT JOIN 关键字会从右表 (Course) 那里返回所有的行,即使在左表 (Teacher) 中没有匹配的行。