4.外连接查询

在前面讲述的连接操作中,返回的结果都是满足连接条件的记录。有些时候,开发人员或者用户对于不满足连接条件的部分记录也感兴趣,这个时候就需要使用外连接查询。外连接查询不仅可以返回满足连接条件的记录,对于一个数据表中在另一个数据表中不匹配的记录也可以返回。外连接查询主要包括三种:左外连接、右外连接和全外连接。

左外连接

左外连接中查询的结果中不仅将显示满足连接条件的记录,而且还包括左侧表中不满足查询条件的记录。在Oracle数据库中,可以使用加号运算符(+)来表示左外连接。当该加号运算符(+)出现在连接条件的左边时,就称之为左外连接。其语法格式如下:

SELECT 表名1.字段, 表名2.字段 ….

FROM 表名1,表名2

WHERE 表名1.字段1(+)=表名2.字段2

其中,SELECT 语句中表名1.字段和表名2.字段表示指定数据表1和数据表2中要查询的列;FROM语句中表名1和表名2表示指定连接的数据表的名字;WHERE子句中表名1.字段1(+)=表名2.字段2表示左外连接。此时,表名1.字段1所在的列的值将会被全部查询出来。

在MySQL数据库和Microsoft SQL Server数据库中可以使用LEFT[OUTER] JOIN关键字实现,其中OUTER关键字是可选的。使用LEFT[OUTER] JOIN关键字实现左外连接的语法规则如下:

SELECT 表名1.字段, 表名2.字段 ….

FROM 表名1 LEFT JOIN表名2

ON 表名1.字段1=表名2.字段2

这里使用LEFT JOIN关键字代替SQL语句中FROM语句里的逗号,使用ON子句代替标准SQL语句中的WHERE子句,并将SQL语句中表示左外连接的加号运算符(+)去除。

右外连接

在Oracle数据库中,当该加号运算符(+)出现在连接条件的右边时,就称之为右外连接。其语法格式如下:

SELECT 表名1.字段, 表名2.字段 ….

FROM 表名1,表名2

WHERE 表名1.字段1=表名2.字段2(+)

在MySQL和Microsoft SQL Server数据库中可以使用RIGHT [OUTER] JOIN关键字实现,其中OUTER关键字是可选的。使用RIGHT [OUTER] JOIN关键字实现左外连接的语法规则如下:

SELECT 表名1.字段, 表名2.字段 ….

FROM 表名1 RIGHT JOIN表名2

ON 表名1.字段1=表名2.字段2

全外连接

全外连接中查询的结果中不仅将显示左侧表中不满足连接条件的记录,而且还会显示右侧表中不满足查询条件的记录。全外连接可以认为是左外连接与右外连接的合集(不包括重复行)。

全外连接可以使用FULL [OUTER] JOIN关键字实现,其中OUTER关键字是可选的。使用FULL [OUTER] JOIN关键字实现左外连接的语法规则如下:

SELECT 表名1.字段, 表名2.字段 ….

FROM 表名1 FULL JOIN表名2

ON 表名1.字段1=表名2.字段2

5.集合查询

在SQL的连接查询语句中,还有一种查询方式就是结合查询。集合查询主要包括三种:并操作、交操作和差操作。其中交操作和差操作并不是对目前主流的所有的数据库的适用。

并操作(UNION)

执行并操作使用的关键字是UNION。并操作返回的结果集是包括了两个查询语句中查询出来的所有不同的行,不包含重复行。其语法格式如下:

SELECT 语句1

UNION

SELECT 语句2

其中语句1和语句2表示的是两个用于查询的SELECT语句。UNION关键字表示对这两个查询语句查询出来的结果进行并操作。这里需要保证SELECT 语句1和SELECT 语句2中查询出的列数必须相同,而且对应的列的数据类型必须一致。

交操作(INTERSECT)

执行交操作使用的关键字是INTERSECT。交操作返回的结果集包括了连接查询结果的公共行。交操作中不会出现重复行。其语法格式如下:

SELECT 语句1

INTERSECT

SELECT 语句2

其中语句1和语句2表示的是两个用于查询的SELECT语句。INTERSECT关键字表示对这两个查询语句查询出来的结果进行交操作。这里需要保证SELECT 语句1和SELECT 语句2中查询出的列数必须相同,而且对应的列的数据类型必须一致。

差操作(MINUS)

执执行交操作使用的关键字是MINUS。差操作返回的记录结果集是只在第一个SELECT语句中出现存在,但不存在于第二个SELECT语句的查询结果中。在其语法格式如下:

SELECT 语句1

MINUS

SELECT 语句2bitsCN.com

php join() 函数获取由数组元素组合成的字符串。本文章向码农介绍php join() 函数的使用方法和基本实例,感兴趣的码农可以参考一下。定义和用法join() 函数返回由数组元素组合成的字符串。join() 函数是 implode() 函...

一.Join语法概述join 用于多表中字段之间的联系,语法如下:... FROM table1 INNER|LEFT|RIGHT JOIN table2 ON conditionatable1:左表;table2:右表。JOIN 按照功能大致分为如下三类:INNER JOIN(内连接,...

hash join(HJ)是一种用于equi-join(而anti-join就是使用NOT IN时的join)的技术。在Oracle中,它是从7.3开始引入的,以代替sort

一、 hash join概念

hash join(HJ)是一种用于equi-join(而anti-

这篇文章主要介绍了Mysql join操作的相关资料,需要的朋友可以参考下 join的类型1. 内联结:将两个表中存在联结关系的字段符合联结关系的那些记录形成记录集的联结。2. 外联结:分为...

这篇文章主要介绍了Mysql join操作的相关资料,需要的朋友可以参考下 join的类型1. 内联结:将两个表中存在联结关系的字段符合联结关系的那些记录形成记录集的联结。2. 外联结:分为...

Left join , Right Join, Inner Join 的相关内容,非常实用

一.先看一些最简单的例子

例子

Table Aaid adate 1 a1 2 a2 3 a3

TableB

bid bdate 1 b1 2

Join是关系型数据库系统的重要操作之一,SQL Server中包含的常用Join:内联接、外联接和交叉联接等1.1.1 摘要 Join是关系型数据库系统的重要操作之一,SQL Server中包含的常用Join:内联接、外联接和交叉联...

...。MySQL数据库支持如下的联接查询:

CROSS JOIN(交叉联接)

INNER JOIN(内联接)

OUTER JOIN(外联接)

其它

在进行各种联接操作时,一定要回忆一下在《SQL逻辑查询语句执...

数据库常见的join方式有三种:inner join, left outter join, right outter join(还有一种full join,因不常用,本文不讨论)。这三种连接方式都是将两个以上的表通过on条件语句,拼成一个大表。

以下是它们的共同点:...

...)中,表连接的语法可以参见MySQL官方手册:MySQL官方手册-JOIN在查询中,连接的语法类似SELECT select_expr FROM table_referencestable_references(对表的引用)的定义如下(也可以看成