SQL_left_join出现重复数据的处理——产品经理数据实战笔记003

236 阅读1分钟

SQL_left_join出现重复数据的原因

使用left join, A表与B表所显示的记录数为 1:1 或 1:0,A表的所有记录都会显示,B表只显示符合条件的记录。 但如果B表符合条件的记录数大于1条,就会出现1:n的情况,这样left join后的结果,记录数会多于A表的记录数。 所以解决办法都是从一个出发点出发,使A表与B表所显示的记录数为 1:1对应关系。

解决方法

使用非唯一标识的字段做关联 1 DISTINCT select DISTINCT(id) from a left join b on a.id=b.aid DISTINCT查询结果是 第一个表唯一的数据 重复的结果没显示出来

2 GROUP BY select * from a left join(select id from b group by id) as b on a.id=b.aid 拿出b表的一条数据关联 使A表与B表所显示的记录数为 1:1对应关系。

blog.csdn.net/ZYC88888/ar…