简单说明问题出现的原因:
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:
1,解释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怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除

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

mysql | left join 出现的结果会重复的问题相关推荐

  1. mysql的联表查询和去重复数据

    mysql的联表查询和去重复数据 /* SQLyog Ultimate v10.00 Beta1 MySQL - 5.7.17-log : Database - pusmtnew ********** ...

  2. 一文搞懂MySQL的Join

    点击上方 "程序员小乐" ,关注公众号 8点20分,第一时间与你相约 每日英文 A single hand that wipes tears during failures is ...

  3. JAVA秒杀mysql层实现_一文搞懂MySQL的Join,聊一聊秒杀架构设计

    正文 MySQL的Join到底能不能用 经常听到2种观点: join性能低,尽量少用 多表join时,变为多个SQL进行多次查询 其实对于上面的观点一定程度上是正确的,但不是完全正确.但之所以流传这么 ...

  4. 唠唠MySQL的join

    准备条件: 建个库: create database test; use test; 建立t1,t2两张表,然后在t1插入100行数据,t2插入1000行数据: CREATE TABLE `t2` ( ...

  5. mysql的join三种算法_MySQL系列(九)---MySQL几种JOIN算法

    本文主要记录了 MySQL的JOIN语句的NLJ.BLJ和MySQL8.0新增的Hash Join算法,及相关优化如MRR.BKA等,最后回答了到底能不能使用JOIN,驱动表又该如何选择等问题. 1. ...

  6. MySQL之Join分析

    MySQL之join分析 https://www.cnblogs.com/BeginMan/p/3754322.html SELECT A.*,B.channel_name FROM sms_task ...

  7. MySQL的Join

    1.Join用法 Join连接两张表,大致分为内连接,外连接,右连接,左连接,自然连接. 内连接又叫等值连接,此时的inner可以省略. USING语句 MySQL中连接SQL语句中,ON子句的语法格 ...

  8. 我想说:mysql 的 join 真的很弱

    (给视学算法加星标,提高Java技能) 转自:ITPUB博客,作者:e71hao blog.itpub.net/30393770/viewspace-2650450/ 一. 问题提出: <阿里巴 ...

  9. mysql right join实例_MySQL表LEFT JOIN左连接与RIGHT JOIN右连接的实例教程

    LEFT JOIN 语法用法与实例MySQL LEFT JOIN 语法 SQL(MySQL) LEFT JOIN 会取得左表(table1)全部记录,即使右表(table2)并无对应匹配记录.LEFT ...

最新文章

  1. webpack项目代理异常解决
  2. 创建MySql用户并给用户授权,设置mariadb默认编码,修改mariadb数据存储目录datadir...
  3. SNF快速开发平台MVC-自由排序组件
  4. 看完这篇你就明白,为什么说大部分企业建设数据中台都会失败?
  5. sql子句的执行顺序_SQL Server查询执行计划– WHERE子句的示例
  6. [Luogu1216][USACO1.5]数字三角形 Number Triangles
  7. 4、http编程——setsockopt函数
  8. MSP430 F5529 单片机 OLED 音乐播放器 八音盒 蜂鸣器 音乐
  9. windows7下预览psd
  10. java long精度问题_解决Long类型超过16位丢失精度问题的两种方法
  11. 用谷歌浏览器模拟打开天眼查网站并爬取需要的数据
  12. 史玉柱和他老同学的一段故事
  13. java咖啡平台,22年最新
  14. 计算机操作系统u盘的安装方法,怎么直接用u盘装系统操作教程
  15. python开发12306抢票_如何利用 Python 实现12306抢票?
  16. AprilTag中的apriltag.c文件
  17. python爬虫———多线程threading模块爬取抖音用户信息
  18. Flutter学习之Dart语言基础(内置类型)
  19. 史上最强ASR非特定人声语音识别模块,完爆LD3320
  20. 12【不定式  动名词】to-infinitive gerund

热门文章

  1. html 标签英文全称,html标签英文全称
  2. 转:关于ASP操作Access数据库时出现死锁.ldb的解决方法
  3. 二维码门禁(ssm做后台)
  4. php上传文件时报错:only variables should be passed by reference
  5. pacs系统服务器配置需求,pacs系统服务器配置
  6. C语言:记录在主线程中停止子线程
  7. 阿里巴巴2016年-校招-实习生岗位-内推
  8. 真实场景的双目立体匹配(Stereo Matching)获取深度图详解
  9. 互联网春招和秋招的区别
  10. 一个玩游戏的失足青年,转行做游戏开发到教育的挣扎过程(3)