java处理大量数据查重合并,MySQL数据查询合并

1.场景:

业务表中有30w数据,动态根据选定的字段,进行查重合并

2.解决方式:

sql语句根据传过来的条件,使用gruop by进行分组,使用GROUP_CONCAT获取每组中的对应id,根据id进行相关的业务操作,由于重复数据量大,使用了limit 100,进行数据量的限制,进行分批处理

3.演示sql

SELECT
	GROUP_CONCAT( RS.alumniuser_id ) AS groupAlumniIds  //获取每组中的对应id
FROM
	(
	SELECT
		au.*
	FROM
		alumniuser au
	WHERE
		( au.isdelete = 0 ) 
		AND 1 = 1 
		AND au.isdelete != 1 
		AND au.organizationId = 1 
	GROUP BY
		au.alumniuser_id 
	) RS 
GROUP BY
	RS.NAME 
HAVING
	( COUNT( 1 ) > 1 ) 
	LIMIT 100

返回一个List字符串,遍历集合,拿到每组的id,进行业务的操作
4.参考链接:sql函数使用详解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值