sql中的几种连接查询,类型及详解

  • Post author:
  • Post category:其他


一、类型


1、内连接(join或inner join)


有两种,显式的和隐式的,返回连接表中

符合连接条件和查询条件的数据行

。(所谓的链接表就是数据库在做查询形成的中间表)。

语句1:隐式的内连接,没有inner join,形成的中间表为两个表的笛卡尔积。

select o.id,o.order_number,c.id,c.name from customers c, orders o wherec.id=o.customer_id;

语句2:显示的内连接,一般称为内连接,有inner join,形成的中间表为两个表经过on条件过滤后的笛卡尔积。

select o.id,o.order_number,c.id,c.name from customers c inner join orders o onc.id=o.customer_id;


2、外连接(outer join)


外连不但返回符合连接和查询条件的数据行,还返回不符合条件的一些行。左表就是在“(left outer join)”关键字左边的表。右表当然就是右边的了。在三种类型的外连接中,outer 关键字是可省略的

外连接分三类:

①左外连接(left join或left outer join)

②右外连接(right join或right outer join)

③全外连接(full join或full outer join)


1>共同点:


都返回符合连接条件和查询条件(即:内连接)的数据行


2>不同点:


左外连接还返回左表中不符合连接条件单符合查询条件的数据行。

右外连接还返回右表中不符合连接条件单符合查询条件的数据行。

全外连接还返回左表中不符合连接条件单符合查询条件的数据行,并且还返回右表中不符合连接条件单符合查询条件的数据行。全外连接实际是上左外连接和右外连接的数学合集(去掉重复),即“全外=左外 union 右外”。

例子:

语句5:左外连接(left outer join)

select o.id,o.order_number,o.customer_id,c



版权声明:本文为weixin_42976139原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。