附实现sql连接的4种方法 sql自然连接语句


附实现sql连接的4种方法 sql自然连接语句

文章插图
1、内联接(典型的联接运算,使用像 = 或 <> 之类的比较运算符) 。包括相等联接和自然联接 。
内联接使用比较运算符根据每个表共有的列的值匹配两个表中的行 。例如,检索 students和courses表中学生标识号相同的所有行 。
2、外联接 。外联接可以是左向外联接、右向外联接或完整外部联接 。
在 FROM子句中指定外联接时,可以由下列几组关键字中的一组指定:
1)LEFT JOIN或LEFT OUTER JOIN
左向外联接的结果集包括 LEFT OUTER子句中指定的左表的所有行,而不仅仅是联接列所匹配的行 。如果左表的某行在右表中没有匹配行,则在相关联的结果集行中右表的所有选择列表列均为空值 。
2)RIGHT JOIN 或 RIGHT OUTER JOIN
右向外联接是左向外联接的反向联接 。将返回右表的所有行 。如果右表的某行在左表中没有匹配行,则将为左表返回空值 。
3)FULL JOIN 或 FULL OUTER JOIN
完整外部联接返回左表和右表中的所有行 。当某行在另一个表中没有匹配行时,则另一个表的选择列表列包含空值 。如果表之间有匹配行,则整个结果集行包含基表的数据值 。
3、交叉联接
交叉联接返回左表中的所有行,左表中的每一行与右表中的所有行组合 。交叉联接也称作笛卡尔积 。
FROM 子句中的表或视图可通过内联接或完整外部联接按任意顺序指定;但是,用左或右向外联接指定表或视图时,表或视图的顺序很重要 。有关使用左或右向外联接排列表的更多信息,请参见使用外联接 。
例子:
————————————————-
a表 id name b表 id job parent_id
1 张3 1 23 1
2 李四 2 34 2
3 王武 3 34 4
a.id同parent_id 存在关系
————————————————–
1) 内连接
select a.*,b.* from a inner join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
2)左连接
select a.*,b.* from a left join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
3 王武 null
3) 右连接
select a.*,b.* from a right join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
null 3 34 4
4) 完全连接
select a.*,b.* from a full join b on a.id=b.parent_id
结果是
1 张3 1 23 1
2 李四 2 34 2
null 3 34 4
3 王武 null
——————————————————————————————–
一、交叉连接(CROSS JOIN)
交叉连接(CROSS JOIN):有两种,显式的和隐式的,不带ON子句,返回的是两表的乘积,也叫笛卡尔积 。
例如:下面的语句1和语句2的结果是相同的 。
语句1:隐式的交叉连接,没有CROSS JOIN 。
SELECT O.ID, O.ORDER_NUMBER, C.ID, C.NAME
FROM ORDERS O , CUSTOMERS C
WHERE O.ID=1;
语句2:显式的交叉连接,使用CROSS JOIN 。
SELECT O.ID,O.ORDER_NUMBER,C.ID,
C.NAME
FROM ORDERS O CROSS JOIN CUSTOMERS C
WHERE O.ID=1;
语句1和语句2的结果是相同的,查询结果如下:
二、内连接(INNER JOIN)
内连接(INNER JOIN):有两种,显式的和隐式的,返回连接表中符合连接条件和查询条件的数据行 。(所谓的链接表就是数据库在做查询形成的中间表) 。


以上关于本文的内容,仅作参考!温馨提示:如遇健康、疾病相关的问题,请您及时就医或请专业人士给予相关指导!

「四川龙网」www.sichuanlong.com小编还为您精选了以下内容,希望对您有所帮助: