在编写大量数据的时候,我们经常会碰到很多个数据表关联的数据问题。现在我可以进行如下总结:
数据库中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的一致。