SQL Join 语句用于根据两个或多个表之间的公共字段组合数据或行。不同类型的连接如下:
- INNER JOIN
- LEFT JOIN
- RIGHT JOIN
- FULL JOIN
考虑以下两个表格:
Student
StudentCourse
最简单的连接是INNER Join。
只要满足条件,INNER JOIN关键字将从两个表中选择所有行。该关键字将通过合并两个表中满足条件的所有行来创建结果集,即公共字段的值将是相同的。
语法 :
table1 : 第一个表.
table2 : 第二个表
matching_column : 两个表共用的列.
注意 :我们也可以用JOIN来代替INNER JOIN。JOIN与INNER JOIN相同。
示例查询(内连接)
这个查询将显示注册不同课程的学生的姓名和年龄。
输出 :
这个联接返回联接左侧表的所有行,并匹配联接右侧表的行。对于右边没有匹配行的行,结果集将包含 null . 左连接也称为左外连接。
语法:
table1: 第一个表.
table2: 第二个表
matching_column: 两个表共用的列.
注意 :我们也可以使用LEFT OUTER JOIN来代替LEFT JOIN,两者是相同的。
示例查询(LEFT JOIN) :
输出 :
右连接类似于左连接。这个联接返回联接右侧表的所有行,并返回联接左侧表的匹配行。对于左侧没有匹配行的行,结果集将包含 null . 右连接也称为右外连接。
语法:
table1: 第一个表.
table2: 第二个表
matching_column: 两个表共用的列.
注意 :我们也可以使用RIGHT OUTER JOIN来代替RIGHT JOIN,两者是相同的。
查询示例(RIGHT JOIN):
输出:
FULL JOIN通过组合LEFT JOIN和RIGHT JOIN的结果来创建结果集。结果集将包含来自两个表的所有行。对于没有匹配的行,结果集将包含 NULL values.
语法:
table1: 第一个表.
table2: 第二个表
matching_column: 两个表共用的列.
示例查询(全部加入) :
输出:
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/4493.html