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

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Fantasy_2/article/details/52623876

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

数据库中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的一致。

展开阅读全文

没有更多推荐了,返回首页