- 内连接 :
inner
、inner join
- 外连接 :
outer join
- 左外连接 :
left outer join
- 左连接 :
left join
- 右外连接
right outer join
- 右连接:
right join
- 左外连接 :
- 全连接
full join
、union
现在有2张表,a表和b表,数据和表结构如下
内连接查询的是两张表的并集,也就是a表和b表都必须有数据才能查询出来;
以下三个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据
-- join
select * from a join b on a.id = b.id
-- inner join
select * from a inner join b on a.id = b.id
-- 逗号的连表方式就是内连接
select * from a , b where a.id = b.id
是以左表为基础,根据on后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出on后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。
下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3、4的数据
-- left join
select * from a left join b on a.id = b.id
-- left outer join
select * from a left outer join b on a.id = b.id
是以右表为基础,根据on后给出的两表的条件将两表连接起来。结果会将右表所有的查询信息列出,而左表只列出on后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。
下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据
-- right join
select * from a right join b on a.id = b.id
-- right outer join
select * from a right outer join b on a.id = b.id
全连接显示两侧表中所有满足检索条件的行。
oracle的全连接
oracle
的全连接查询可以直接用full join
,
select * from a full join b on a.id = b.id
mysql的全连接
mysql
中没有full join
,mysql
可以使用union
实现全连接;
select * from a left join b on a.id = b.id
union
select * from a right join b on a.id = b.id