通过内存去重替换SQL中distinct,优化SQL查询效率

一、背景

运维同事收到了生产环境的一条慢SQL告警,执行时间达到了10+秒,分析了业务场景,属于正常查询业务,而且SQL语句是上个版本新增的需求,于是在慧眼上,将SQL链路截图发给了开发进行修复。

二、分析

通过对SQL的执行索引情况分析,发现最后耗时在了distinct阶段,于是就想办法将去重放在内存中进行优化。

三、方案

1:SQL整改

优化前SQL

sql 复制代码
select distinct color,name .....

优化后SQL

sql 复制代码
select color,name .....

2:重写hashcode和equals方法

这里用Car举例,只是为了还原业务场景

java 复制代码
public class Car{
	private String color;
	private String name;
	@override
	public boolean equals(Object obj){
    	if(this == obj){
    		return true;
    	} 
    	if(obj == null || getClass() != obj.getClass()){
			return false;
		}
		Car car = (Car) obj;
		return StringUtils.equals(car.getColor(),this.color)
		       && StringUtils.equals(car.getName(),this.name);
    }

   @Override
   public int hashCode(){
		return Objects.hash(color,name);
   }
}

优化后,去掉了SQL中的distinct。

分批查询数据,最后对结果去重。

java 复制代码
List<Car> result = new ArrayList<>();
ListGroupUtils.groupListBySize(resultList,1000).forEach(
	list -> result.addAll(xxDao.findXXX(list))
);
return result.stream().distinct().collect(Collectors.toList());
相关推荐
叫我莫言鸭14 小时前
关于word生成报告的POI学习2循环标题内容
java·学习·word
七夜zippoe14 小时前
Spring与MyBatis整合原理及事务管理
java·spring·mybatis·事务·mapper
yaoxin52112314 小时前
278. Java Stream API - 限制与跳过操作全解析
java·开发语言·python
短剑重铸之日14 小时前
《深入解析JVM》第五章:JDK 8之后版本的优化与JDK 25前瞻
java·开发语言·jvm·后端
love530love14 小时前
【探讨】“父级/基环境损坏,子环境全部失效”,如何避免 .venv 受父级 Python 损坏影响?
java·开发语言·人工智能·windows·python·编程·ai编程
麦聪聊数据14 小时前
敏感数据安全吗?基于字段级血缘的 PII 数据全链路追踪
数据库·sql·安全
java硕哥14 小时前
Spring源码debug方法
java·后端·spring
杂货铺的小掌柜15 小时前
MAC版IDEA常用快捷键
java·macos·intellij-idea
在风中的意志15 小时前
[数据库SQL] [leetcode-511] 511. 游戏玩法分析 I
数据库·sql·游戏
xjz184215 小时前
JVM虚拟线程:JEP 444开启Java并发编程新纪元
java