inner join 和 left join、right join区别
简单一句话先总结:inner join 只返回两表条件相同的数据行,其余两个分别以左、右表为基准返回各自基准表的全部数据行,未满足条件部分以 null 返回填入!
实际场景:
犯错: 本来想返回全部值,不论条件是否成立,但实际却是返回了 只允许条件满足的数据行。导致不满足条件的数据无法从数据库查询出来给以前端显示页面上!
解决方案:
将 inner join 改为 left join 即可。
个人总结:
sql的left join 、right join 、inner join之间的区别
- ##### inner join(等值连接) 只返回两个表中联结字段相等的行
- ##### left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录
- ##### right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录
- 举例如下:
表A记录如下: aID | aNum —|— 1 | a20050111 2 | a20050112 3 | a20050113 4 | a20050114 5 | a20050115
表B记录如下: bID | bName —|— 1 | 2006032401 2 | 2006032402 3 | 2006032403 4 | 2006032404 8 | 2006032408
1. left join
select * from A // 后面的表名 A 就是 左边
left join B // B 就是右边 这里 以 左边 表A 为准返回数据行
on A.aID = B.bID
结果如下:
aID | aNum | bID | bName |
---|---|---|---|
1 | a20050111 | 1 | 2006032401 |
2 | a20050112 | 2 | 2006032402 |
3 | a20050113 | 3 | 2006032403 |
4 | a20050114 | 4 | 2006032404 |
5 | a20050115 | NULL | NULL |
结果说明: left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的. 换句话说,左表(A)的记录将会全部表示出来,而右表(B)只会显示符合搜索条件的记录(例子中为: A.aID = B.bID). B表记录不足的地方均为NULL.
2. right join
select * from A // 后面的表名 A 就是 左边
right join B // B 就是右边 这里 以 右边 表A 为准返回数据行
on A.aID = B.bID
aID | aNum | bID | bName |
---|---|---|---|
1 | a20050111 | 1 | 2006032401 |
2 | a20050112 | 2 | 2006032402 |
3 | a20050113 | 3 | 2006032403 |
4 | a20050114 | 4 | 2006032404 |
NULL | NULL | 8 | 2006032408 |
结果说明: 仔细观察一下,就会发现,和left join的结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充.
3. inner join
select * from A
innerjoin B
on A.aID = B.bID
aID | aNum | bID | bName |
---|---|---|---|
1 | a20050111 | 1 | 2006032401 |
2 | a20050112 | 2 | 2006032402 |
3 | a20050113 | 3 | 2006032403 |
4 | a20050114 | 4 | 2006032404 |
很明显 这里只返回了 4 行数据!!!,这里只显示出了 A.aID = B.bID的记录.这说明inner join并不以谁为基础,它只显示符合条件的记录.