Mysql一些复杂的sql语句(查询与删除重复的行)
程序员文章站
2022-03-26 13:56:04
...
这篇文章主要介绍了Mysql一些复杂的sql语句(查询与删除重复的行),需要的朋友可以参考下
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一些复杂的sql语句(查询与删除重复的行)的详细内容,更多请关注其它相关文章!
上一篇: 避免Smarty与CSS语法冲突的方法
推荐阅读
-
Oracle与MySQL的分页查询sql语句格式实例讲解
-
关于mysql中删除重复记录,并保留重复数据中的一条数据的SQL语句的深入理解
-
Mysql一些复杂的sql语句(查询与删除重复的行)
-
oracle分页、mysql分页、删除重复记录及简单的sql的查询教程
-
MySQL中删除完全重复数据的准确SQL语句
-
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备
-
mysql中删除完全重复数据的准确SQL语句_MySQL
-
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备
-
查询语句很复杂-mysql由四张表查出一张新的表,sql语句太复杂,求助!!!!
-
查询语句很复杂-mysql由四张表查出一张新的表,sql语句太复杂,求助!!!!