SQL之inner join 和 left join、right join区别立

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并不以谁为基础,它只显示符合条件的记录.

MYSQL  SQL