mysql left join 出现的结果会重复

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查询结果是  第一个表唯一的数据   重复的结果没显示出来

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表的最后一条数据关联

转载于:https://www.cnblogs.com/ampl/p/9081746.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值