例如:下面的语句3和语句4的结果是相同的 。
语句3:隐式的内连接,没有INNER JOIN,形成的中间表为两个表的笛卡尔积 。
SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME
FROM CUSTOMERS C,ORDERS O
WHERE C.ID=O.CUSTOMER_ID;
语句4:显示的内连接,一般称为内连接,有INNER JOIN,形成的中间表为两个表经过ON条件过滤后的笛卡尔积 。
SELECT O.ID,O.ORDER_NUMBER,C.ID,C.NAME
FROM CUSTOMERS C INNER JOIN ORDERS O ON C.ID=O.CUSTOMER_ID;
语句3和语句4的查询结果:
三、外连接(OUTER JOIN):外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行 。外连接分三类:左外连接(LEFT OUTER JOIN)、右外连接(RIGHT OUTER JOIN)和全外连接(FULL OUTER JOIN) 。
三者的共同点是都返回符合连接条件和查询条件(即:内连接)的数据行 。不同点如下:
左外连接还返回左表中不符合连接条件单符合查询条件的数据行 。
右外连接还返回右表中不符合连接条件单符合查询条件的数据行 。
全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行 。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 UNION 右外” 。
说明:左表就是在“(LEFT OUTER JOIN)”关键字左边的表 。右表当然就是右边的了 。在三种类型的外连接中,OUTER 关键字是可省略的 。
下面举例说明:
语句5:左外连接(LEFT OUTER JOIN)
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
语句6:右外连接(RIGHT OUTER JOIN)
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O RIGHT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
注意:WHERE条件放在ON后面查询的结果是不一样的 。例如:
语句7:WHERE条件独立 。
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID
WHERE O.ORDER_NUMBER<>’MIKE_ORDER001′;
语句8:将语句7中的WHERE条件放到ON后面 。
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID AND O.ORDER_NUMBER<>’MIKE_ORDER001′;
从语句7和语句8查询的结果来看,显然是不相同的,语句8显示的结果是难以理解的 。因此,推荐在写连接查询的时候,ON后面只跟连接条件,而对中间表限制的条件都写到WHERE子句中 。
语句9:全外连接(FULL OUTER JOIN) 。
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O FULL OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
注意:MySQL是不支持全外的连接的,这里给出的写法适合Oracle和DB2 。但是可以通过左外和右外求合集来获取全外连接的查询结果 。下图是上面SQL在Oracle下执行的结果:
语句10:左外和右外的合集,实际上查询结果和语句9是相同的 。
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O LEFT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID
UNION
SELECT O.ID,O.ORDER_NUMBER,O.CUSTOMER_ID,C.ID,C.NAME
FROM ORDERS O RIGHT OUTER JOIN CUSTOMERS C ON C.ID=O.CUSTOMER_ID;
语句9和语句10的查询结果是相同的,如下:
四、联合连接(UNION JOIN):这是一种很少见的连接方式 。Oracle、MySQL均不支持,其作用是:找出全外连接和内连接之间差异的所有行 。这在数据分析中排错中比较常用 。也可以利用数据库的集合操作来实现此功能 。
以上关于本文的内容,仅作参考!温馨提示:如遇健康、疾病相关的问题,请您及时就医或请专业人士给予相关指导!
「四川龙网」www.sichuanlong.com小编还为您精选了以下内容,希望对您有所帮助:- 实现负载均衡集的技巧 负载均衡集群如何实现
- mysql切换主从方法和如何使用 mysql主从切换步骤
- mysql数据库怎么查看优化 mysql数据库查询语句优化
- 附虚拟机安装操作教程 虚拟机安装操作系统的主要步骤有哪些
- 微信关联聊天记录同步吗 如何关闭附近的人
- 揭晓无法连接的原因和解决法 sql server2008连接不上服务器
- 心梗急救措施
- 故宫是哪个门都可以进吗?附近还有什么可玩的? 故宫哪个门进
- 创建数据库的教程 免费mysql数据库空间
- 代码创建数据库的步骤 sql数据库安装失败怎么办