Mysql一些复杂的sql语句(查询与删除重复的行)
16lz
2021-12-31
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)
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;
更多相关文章
- Android(安卓)-- Android(安卓)JUint 与 Sqlite
- android 当系统存在多个Launcher时,如何设置开机自动进入默认的La
- Android(安卓)SQLiteDatabase的使用
- android一种较为复杂的布局参考(xml文件)
- android 通话记录次数
- Android(安卓)SQLiteDatabase的使用
- 关于Android/java的复杂对象的深拷贝和浅拷贝
- android实现关键字搜索功能
- 我的android 第14天 - 使用SQLiteDatabase操作SQLite数据库