主页 > 知识库 > Mysql一些复杂的sql语句(查询与删除重复的行)

Mysql一些复杂的sql语句(查询与删除重复的行)

热门标签:昆明智能外呼系统中心 长安区违法建房地图标注 手机用地图标注工具 地图标注培训 智能电销机器人靠谱么 安国在哪里办理400电话 南宋地图标注黄河华山 电销机器人说明书 电销机器人公众号推送

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;

您可能感兴趣的文章:
  • 使用SQL批量替换语句修改、增加、删除字段内容
  • SQL语句实现删除重复记录并只保留一条
  • 必须会的SQL语句(四) 数据删除和更新
  • 必须会的SQL语句(二) 创建表、修改表结构、删除表
  • 使用sql语句创建和删除约束示例代码
  • oracle使用sql语句增加字段示例(sql删除字段语句)
  • MySQL中批量删除指定前缀表的sql语句
  • SQL语句删除和添加外键、主键的方法
  • MySQL删除数据Delete与Truncate语句使用比较
  • 简单了解SQL常用删除语句原理区别

标签:武汉 潜江 江门 南昌 长沙 东莞 吉安 合肥

巨人网络通讯声明:本文标题《Mysql一些复杂的sql语句(查询与删除重复的行)》,本文关键词  Mysql,一些,复杂,的,sql,语句,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Mysql一些复杂的sql语句(查询与删除重复的行)》相关的同类信息!
  • 本页收集关于Mysql一些复杂的sql语句(查询与删除重复的行)的相关信息资讯供网民参考!
  • 推荐文章