mysql 中 left join 出现的结果会重复的问题
2018-03-30 16:24
381 查看
简单说明问题出现的原因:
MySQL left join 语句格式为: A LEFT JOIN B ON 条件表达式
left join 是以A表为基础,A表即左表,B表即右表。
左表(A)的记录会全部显示,而右表(B)只会显示符合条件表达式的记录,如果在右表(B)中没有符合条件的记录,则记录不足的地方为NULL。
所以解决办法 都是从一个出发点出发,使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 语句格式为: 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(25):事务的隔离级别出现问题之 不可重复读
- Mysql 解决left join 数据重复的问题
- mysql应用过程中出现的主键重复的问题
- 使用mysql的limit进行分页时出现重复问题
- Mysql 解决left join 数据重复的问题
- 使用mysql的limit进行分页时出现重复问题
- mybatis generator MySQL 自增ID出现重复问题MySQLIntegrityConstraintViolationException
- Ubuntu Server 16.04安装MySQL设置远程访问出现问题的完美解决方案(error:10061)
- MySQL查询重复出现次数最多的记录
- windows系统下解决Qt连接MySQL数据库时出现的问题:QMYSQL driver not loaded
- 经典面试问题: Top K 之 ---- 海量数据找出现次数最多或,不重复的。
- 解决mysql安装时出现error Nr.1045问题的方法
- mysql导出数据时出现--secure-file-priv 问题的解决办法
- C#中调用mysql存储过程出现的问题
- mysql安装时可能出现的问题
- MySQL在分页查询中出现数据重复
- struts2的jsp页面提交后,命名空间重复出现的问题
- mysql5.1升级5.6步骤以及出现问题解决方法
- 就Navicat for MySQL出现的乱码问题进行讨论
- mysql备份及恢复出现的问题