美文网首页php-learning
对mysql left join 出现的重复结果去重

对mysql left join 出现的重复结果去重

作者: 80a7ba2dd31d | 来源:发表于2019-07-11 09:18 被阅读0次

对mysql left join 出现的重复结果去重

简单说明问题出现的原因:

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

查询结果是 第一个表唯一的数据 重复的结果没显示出来

相关文章

网友评论

    本文标题:对mysql left join 出现的重复结果去重

    本文链接:https://www.haomeiwen.com/subject/ijalkctx.html