mysql删除重复数据

这篇博客探讨了如何使用SQL查询重复数据,并提供了一种安全的方式删除这些重复记录。通过SELECT语句,作者展示了找出重复基金编号和日期的记录,然后使用DELETE语句配合子查询来逐一移除这些重复项,确保每次只删除每组重复数据中的一条。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/*查询重复数据*/
SELECT
	* 
FROM
	index_price 
WHERE
	( fund_number, date ) IN ( SELECT fund_number, date FROM index_price GROUP BY fund_number, date HAVING count(*)> 1 ) 
ORDER BY
	fund_number,
	date DESC;
	
	/*删除重复数据,一次只删除每组重复数据中的一条数据,若一组数据多次重复,要执行多次*/
	
DELETE 
FROM
	index_price 
WHERE
	id IN (
	SELECT
		id 
	FROM
		(
		SELECT
			max( id ) id 
		FROM
			index_price 
		WHERE
			( fund_number, date ) IN ( SELECT fund_number, date FROM index_price GROUP BY fund_number, date HAVING count(*)> 1 ) 
		GROUP BY
			fund_number,
			date 
		) t 
	)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值