MySQL-删除重复数据

在实际应用中,遇到一个这样的问题,MySQL中存储的数据为资讯类数据,在页面展示时会出现多个平台的新闻报导相同的内容,导致页面会出现重复数据。因为数据是每天定期更新,所以最快捷有效的方式是在更新完数据后增加一个去重操作。

实现逻辑如下:

写一个定时删除的脚本,每天定时执行,通过对数据中title进行聚合去重:将数据按title分组,取id最小的数据进行记录,然后将id不在该列表的数据删除。

代码如下:

sql 复制代码
DELETE FROM worldhm_info_major_news
WHERE id NOT IN (
    SELECT MIN(id) min_id
			FROM worldhm_info_major_news
			WHERE pub_date > "2023-09-24 00:00:00"
			GROUP BY title
) AND pub_date > "2023-09-24 00:00:00";

运行上述代码时报错:

该错误大致意思为不能依据某字段值做判断再来更新某字段的值。

解决方法

解决方法:select 的结果再通过一个中间表 select 多一次,就可以避免这个错误

sql 复制代码
DELETE FROM worldhm_info_major_news
WHERE id NOT IN (
select min_id from (
    SELECT MIN(id) min_id
    FROM worldhm_info_major_news
	WHERE pub_date > "2023-09-24 00:00:00"
    GROUP BY title) a
) AND pub_date > "2023-09-24 00:00:00";
相关推荐
GDAL2 分钟前
SQLite 与 MySQL 性能深度对比:场景决定最优解
数据库·mysql·sqlite
troublea5 分钟前
Laravel 8.x新特性全解析
数据库·mysql·缓存
焦糖玛奇朵婷7 分钟前
做盲盒小程序,如何少走弯路?
数据库·程序人生·小程序·开源软件·软件需求
mi200612 分钟前
Linux下安装postgresql记录
数据库·postgresql
清云随笔14 分钟前
MySQL 的常见操作(基础)
数据库·mysql
汇智信科17 分钟前
汇智信科网络考试系统:以技术赋能,重构在线测评新范式
linux·数据库·mysql·oracle·sqlserver·java技术
BullSmall24 分钟前
从2026年春晚 详细分析未来IT行业的发展
linux·运维·服务器·数据库
正在走向自律27 分钟前
高并发场景下一卡通系统数据库架构设计与实践
数据库·分布式·一卡通系统
悠闲蜗牛�1 小时前
Go语言高并发编程深度实战:从原理到性能优化的完整指南
java·运维·数据库