left join 基本用法
A LEFT JOIN B ON 条件表达式
left join 是以A表为基础,A表即左表,B表即右表。
左表(A)的记录会全部显示,而右表(B)只会显示符合条件表达式的记录,如果在右表(B)中没有符合条件的记录,则记录不足的地方为NULL。
使用left join, A表与B表所显示的记录数为 1:1 或 1:0,A表的所有记录都会显示,B表只显示符合条件的记录。
但
如
果
B
表
符
合
条
件
的
记
录
数
大
于
1
条
,
就
会
出
现
1
:
n
的
情
况
,
这
样
l
e
f
t
j
o
i
n
后
的
结
果
,
记
录
数
会
多
于
A
表
的
记
录
数
。
\color{red}{但如果B表符合条件的记录数大于1条,就会出现1:n的情况,这样left join后的结果,记录数会多于A表的记录数。}
但如果B表符合条件的记录数大于1条,就会出现1:n的情况,这样leftjoin后的结果,记录数会多于A表的记录数。
这个是我没想到的。。。我以为left join只会以A表为主,谁曾想,B表还能影响。。。
所以解决办法都是从一个出发点出发,使B表能返回的数据去个重就行了
1、select DISTINCT(id) from a left join b on a.id=b.aid
DISTINCT查询结果是 第一个表唯一的数据 重复的结果没显示出来
2、select * from a left join(select id from b group by id) as b on a.id=b.aid
拿出b表的一条数据关联 使A表与B表所显示的记录数为 1:1对应关系。
3、select * from a left join (select max(id) from b group by id) as b on a.id=b.aid
拿出b表的最后一条数据关联