数据库join及其join子句的意义

在编写大量数据的时候,我们经常会碰到很多个数据表关联的数据问题。现在我可以进行如下总结:

数据库中join语句是指将多个表中的数据并联在一起,然后根据要求找出需要的数据。在SQL语句中join语句包含了如下子句:

1、left join:即使右表中没有匹配数据,也要从左表返回所有行数据,例如:存在A、B、C、D表,A表的列a、m,B表的列b、n,C表的列c、o,D表的列d、p

select A.a,A.m,B.b,B.n,C.c,C.o  from A

left  join B on  B.b=A.id

left  join C on C.c=A.id

where A.id=#{id,jdbcType=VARCHAR}

上面是一个简单left join语句,它的意义在于,当上述语句中根据B表符合与A表关联的数据时,搜索B表b、n数据不存在, 那边左表(即A表)数据依然返回,右表的数据为空。如图:biz0202h为左表,biz0202d为右表。


2、right join:即使左表没有关联语句,也要返回右表数据,顾名思义,与上述语句相反,将上面的语句left改为right即可,得出效果如图:biz0202h为左表,biz0202d为右表。


很明显,右表不存在的数据,即使左表存在,也无法返回该数据,它是以右表为基准的。


3、inner  join :内连接,与join相同,关键字在表中存在至少一条数据,则返回所有行。它是指A与B关联的时候,A表存在数据,且B表也存在数据,则返回所有行。否则,任一个表不存在数据时则不返回行。

select A.a,A.m,B.b,B.n,C.c,C.o  from A

inner  join B on  B.b=A.id

inner  join C on C.c=A.id

where A.id=#{id,jdbcType=VARCHAR}



4、full  join 全连接:关键字在任何表中存在任一一条数据时,都会返回所有行。它是指A与B关联的时候,A或者B表存在数据时,都可返回该行数据。

select A.a,A.m,B.b,B.n,C.c,C.o  from A

full  join B on  B.b=A.id

full  join C on C.c=A.id

where A.id=#{id,jdbcType=VARCHAR}


题外话:

union all:与union相同,关联的表时,其所选择的数据列必须相同,且数据类型一致

select A.a,A.m from  A  union all

select B.b,B.n from  B

其中a的数据类型必须与b的一致,m列的数据类型必须与n的一致。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值