文章插图
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小编还为您精选了以下内容,希望对您有所帮助:- 实现负载均衡集的技巧 负载均衡集群如何实现
- mysql切换主从方法和如何使用 mysql主从切换步骤
- mysql数据库怎么查看优化 mysql数据库查询语句优化
- 附虚拟机安装操作教程 虚拟机安装操作系统的主要步骤有哪些
- 微信关联聊天记录同步吗 如何关闭附近的人
- 揭晓无法连接的原因和解决法 sql server2008连接不上服务器
- 心梗急救措施
- 故宫是哪个门都可以进吗?附近还有什么可玩的? 故宫哪个门进
- 创建数据库的教程 免费mysql数据库空间
- 代码创建数据库的步骤 sql数据库安装失败怎么办