数据库的多变查询,包括左右连接

左连接

是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。

-- 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后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。

-- 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 

内连接

内连接查询的是两张表的并集,也就是A表和B表都必须有数据才能查询出来
-- 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 

全连接

全连接显示两侧表中所有满足检索条件的行。

select * from a full join b on a.id = b.id

知道了上面各个连接的定义,那么(+)到底是什么意思呢?

其实 (+) 是一种左/右连接的特殊表达方式,(+)号一侧代表被连接的对象,直接看下面代码

--左连接:
select A.a,B.a from A LEFT JOIN B ON A.b=B.b;

--等价于 
select A.a,B.a from A,B where A.b = B.b(+);

--右连接:
select A.a,B.a from A RIGHT JOIN B ON A.b=B.b;

--等价于 
select A.a,B.a from A,B where A.b (+) = B.b;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值