SQL之inner join/left join/right join详解

 

表A记录如下:
aID     aData
1           a1
2           a2
3           a3

表B记录如下:
bID     bData
1           b1
2           b2
4           b4

--------------------------------------------------------------

Inner join

两个表a,b相连接,要取出id相同的字段 
select * from a inner join b on a.aid = b.bid这是仅取出匹配的数据. 
此时的取出的是: 
1 a1 b1 
2 a2 b2 


那么left join 指: 
select * from a left join b on a.aid = b.bid 
首先取出a表中所有数据,然后再加上与a,b匹配的的数据 
此时的取出的是: 
1 a1 b1 
2 a2 b2 
3 a3 空字符 


同样的也有right join
指的是首先取出b表中所有数据,然后再加上与a,b匹配的的数据 
此时的取出的是: 
1 a1 b1 
2 a2 b2 
4 空字符 b4
posted @ 2008-12-08 15:14  ike_li  阅读(190)  评论(0)    收藏  举报