mysql使用left join连接出现重复记录
问题描述在使用连接查询的时候,例如以A表为主表,左连接B表,我们期望的是A表有多少条记录,查询结果就有多少条记录,但是可能会出现这样的结果,就是查询出来的记录总条数,多余A表的记录总条数,并且是查询的结果显示出来时有部分列是重复的,简单的说,就是产生了笛卡尔积。问题示例其中A表是用户表(user),字段分别是:IDnameuserid1aaaa...
问题描述
在使用连接查询的时候,例如以A表为主表,左连接B表,我们期望的是A表有多少条记录,查询结果就有多少条记录,但是可能会出现这样的结果,就是查询出来的记录总条数,多余A表的记录总条数,并且是查询的结果显示出来时有部分列是重复的,简单的说,就是产生了笛卡尔积。
问题示例
其中A表是用户表(user),字段分别是:
ID name userid
1 aaaa 10001
2 bbbb 10002
3 ccccc 10003
B表是第一类产品表(product),字段分别是:
ID title time userid
1 标题1 2014-01-01 10002
2 标题2 2014-01-01 10002
3 标题3 2014-01-01 10001
4 标题4 2018-03-20 10002
5 标题5 2018-03-20 10003
这个时候我们使用下面sql 执行的时候发现
selecct * from user left join product on user.userid=product.userid;
执行结果竟然比user表的总数记录多
问题解决
其实这个问题明眼人一眼就看出来了,因为left join的关键字在product表不唯一,所以这部分不唯一的数据就产生了笛卡尔积,导致执行结果多于预期结果。解决的办法就是采用唯一键去关联做链接查询就可以了
更多推荐
所有评论(0)