关于SQL关联查询出现重复数据。

问题记录:关于关联查询多表联查时,关联的条件在A表存在,B表存在,C表存在时(即有别的表存在同样的条件),会造成LEFT JOIN ON后面的条件出现重复的数据。是由于关联查询时多表连接的条件不是唯一条件造成的。

解决方案:1.先找出是哪个表造成的条件不唯一, 2.关联关系上补上唯一条件

SELECT *
FROM tableA a
    left join tableB b on a.instance_id=b.instance_id
    left join tableC c on a.instance_id=c.instanceId 
WHERE 1=1

假设此时出现重复是由于c表中的关联条件并非是唯一条件,

解决方案 1->:

SELECT *

FROM tableA a

left join tableB b on a.instance_id=b.instance_id

left join tableC c on a.instance_id=c.instanceId AND b.bill_date = q.date_time

WHERE 1=1

加上另一个可以解决唯一性的条件即可。 

解决方案 2->:更换关联条件为满足唯一性的条件

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值