mysqlleftjoin出现的结果会重复的问题
简单说明问题出现的原因:
MySQL 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的情况,这样left join后的结果,记录数会多于A表的记录数。
所以解决办法 都是从⼀个出发点出发,使A表与B表所显⽰的记录数为 1:1对应关系。
解决⽅法:
使⽤⾮唯⼀标识的字段做关联
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 table group by id) as b on a.id=b.aid 拿出b表的最后⼀条数据关联
PS:
1,解释distinct,如下例⼦:(**
table
id name
1 a
2 b
3 c
4 c
5 b
⽐如想⽤⼀条语句查询得到name不重复的所有数据,那就必须使⽤distinct去掉多余的重复记录。
select distinct name from table
得到的结果是:
name
a
b
c
好像达到效果了,可是,如果还想要得到的是id值呢?改⼀下查询语句吧:
多表left joinselect distinct name, id from table
结果会是:
id name
1 a
2 b
3 c
4 c
5 b
distinct怎么没起作⽤?作⽤是起了的,不过他同时作⽤了两个字段,也就是必须得id与name都相同的才会被排除
)
采⽤唯⼀键去关联做链接查询
left join的关键字(字段)在product表不唯⼀,所以这部分不唯⼀的数据就产⽣了笛卡尔积,导致执⾏结果多于预期结果。可以⽤唯⼀键(不⼀定要主键,只要唯⼀就⾏)去关联做链接查询就可以了。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论