1.查找重复的行
SELECT * FROM blog_user_relation a WHERE (a.account_instance_id,a.follow_account_instance_id) IN ( SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING
COUNT ( * ) > 1 )
2.删除重复的行(保留一条)
PS:因为mysql的delete,如果被删的表的where条件里有in,且in里面也有此表,那就删除不了。
/* 创建个临时表 */ CREATE TABLE blog_user_relation_temp AS (
SELECT * FROM blog_user_relation a WHERE (a.account_instance_id,a.follow_account_instance_id) IN ( SELECT account_instance_id,follow_account_instance_id FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT ( * ) > 1 ) AND relation_id NOT IN ( SELECT MIN (relation_id) FROM blog_user_relation GROUP BY account_instance_id, follow_account_instance_id HAVING COUNT ( * ) > 1 )); /* 删除数据 */ DELETE FROM `blog_user_relation` WHERE relation_id IN ( SELECT relation_id FROM blog_user_relation_temp); /* 删除临时表 */ DROP TABLE blog_user_relation_temp;