专栏首页快乐学Python对mysql left join 出现的重复结果去重

对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

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

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: 解释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值呢?改一下查询语句吧:

select distinct name, id from table

结果会是:

id name
1 a
2 b
3 c
4 c
5 b

distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得idname都相同的才会被排除

采用唯一键去关联做链接查询

left join的关键字(字段)在product表不唯一,所以这部分不唯一的数据就产生了笛卡尔积,导致执行结果多于预期结果。可以用唯一键(不一定要主键,只要唯一就行)去关联做链接查询就可以了。

我会阅读所有的评论,所以无论你有什么想要说的,或者是想要分享的,甚至是问题之类的,都可以在下面留言。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 如何在 docker 中执行 crontab

    马哥Python
  • Python 优雅的使用参数 - 可变参数(*args & **kwargs)

    可能很多人用了几年的 Python 都没真正使用过可变参数,就比如我,为了学写通用模块,就会对它有需求;或许你经常看 Python 模块库代码,会发现很多函数的...

    马哥Python
  • macos安装LightGBM

    马哥Python
  • Appium—Native+H5混合APP的自动化

    小编所在项目的客户端是比较奇怪的一个APP,大部分页面Android和iOS的客户端只提供了webview的功能,都是由H5处理业务逻辑和用户交互。H5承担了和...

    软测小生
  • Appium—Native+H5混合APP的自动化

    小编所在项目的客户端是比较奇怪的一个APP,大部分页面Android和iOS的客户端只提供了webview的功能,都是由H5处理业务逻辑和用户交互。H5承担了和...

    用户5521279
  • ES6之Set和Map数据结构

    ES6提供了新的数据结构Set,类似数组,元素值都是唯一的,不能重复。Set本身就是一个构造函数。

    wade
  • 使用Oracle with内嵌视图优化一例

    用户1148526
  • Enterprise Library 4.1学习笔记4----缓存应用程序块

    缓存是个啥?以及为啥要用缓存就不废话了,主要是从实用角度讲下怎么用 1.先添加对Microsoft.Practices.EnterpriseLibrary.Ca...

    菩提树下的杨过
  • 【小家Spring】Spring中读取配置的方式,@Value、@PropertySource、@ConfigurationProperties使用详解

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

    YourBatman
  • Metrics:如何让线上应用更加透明?

    上期我们结合《SRE Google 运维解密》,对监控系统进行了一次脉络梳理,知道一旦离开了监控系统,我们就没法辨别一个服务是不是在正常提供服务,就如同线上的服...

    一猿小讲

扫码关注云+社区

领取腾讯云代金券