2 guyeyingwu guyeyingwu 于 2016.02.19 10:24 提问

较大的数据库查找重复记录的问题 2C

我的数据库里有一个表,数据接近有1000万条,现在我需要查找一个叫buyerId的字段重复的记录,由于数据太多我原先写的句子是
SELECT * FROM t_buyer GROUP BY buyerId HAVING COUNT(*)>1
运行了好几个小时都得不到答案,所以请教各位大神,应该怎么解决这个问题

我想要得到的结果是显示重复的记录信息,例如有3个buyerId都是1111,我想要列出这三个人的全部信息,倘若只有一个人的buyerId是1111,便不需要列出

2个回答

caozhy
caozhy   Ds   Rxr 2016.02.19 10:27

对 buyerId 加上索引,用join自己连自己
select distinct t1.buyerId from t_buyer t1
join t_buyer t2 on t1.buyerId = t2.buyerId

guyeyingwu
guyeyingwu 我可能描述的不明白,我不是要筛选掉重复的记录,我是要显示重复的记录,例如张三有两个就列出两个张三的全部信息,李四只有一个的话就不需要列出了
接近 2 年之前 回复
caozhy
caozhy   Ds   Rxr 2016.02.19 10:28
 select distinct t1.buyerId from t_buyer t1
join t_buyer t2 on t1.buyerId = t2.buyerId and t1.id <> t2.id
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!