Mysql一些复杂的sql语句(查询与删除重复的行)
2017-05-20 12:45
549 查看
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;
您可能感兴趣的文章:
相关文章推荐
- mysql删除重复记录语句的方法 作者: 字体:[增加 减小] 类型:转载 时间:2010-06-21 我要评论 查询及删除重复记录的SQL语句,虽然有点乱,但内容还是不错的。 . .
- Oracle 查询并删除重复记录的SQL语句
- 查询|删除同一表内一个或多个字段重复记录的SQL语句
- Oracle 查询并删除重复记录的SQL语句
- 查询和删除表中重复数据sql语句
- Oracle 查询并删除重复记录的SQL语句
- Oracle 查询并删除重复记录的SQL语句
- 查询和删除表中重复数据sql语句
- 如何使用Oracle查询并删除重复记录的SQL语句
- 使用SQL语句对重复记录查询、统计重复次数、删除重复数据
- 一个mysql查询字段重复的sql语句
- Oracle 查询并删除重复记录的SQL语句
- 查询和删除表中重复数据sql语句
- (转)MySQL 查询重复出现次数最多的记录,按出现频率排序(SQL语句)
- 查询并删除重复记录的SQL语句
- 转-查询及删除重复记录的SQL语句
- Oracle 查询并删除重复记录的SQL语句
- 查询并删除重复记录的SQL语句
- 使用SQL语句查询表中重复记录并删除
- 查询及删除重复记录的SQL语句