通过内存去重替换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());
相关推荐
麦麦鸡腿堡4 分钟前
Java绘图技术
java·开发语言
西西学代码2 小时前
Flutter---Stream
java·服务器·flutter
Blossom.1185 小时前
移动端部署噩梦终结者:动态稀疏视觉Transformer的量化实战
java·人工智能·python·深度学习·算法·机器学习·transformer
静若繁花_jingjing5 小时前
IDEA下载
java·ide·intellij-idea
代码丰5 小时前
函数式接口+default接口+springAi 中的ducumentReader去理解为什么存在default接口的形式
java
果汁华7 小时前
java学习连续打卡30天(1)
java
武子康7 小时前
Java-171 Neo4j 备份与恢复 + 预热与执行计划实战
java·开发语言·数据库·性能优化·系统架构·nosql·neo4j
m0_639817157 小时前
基于springboot火锅店管理系统【带源码和文档】
java·spring boot·后端
会编程的林俊杰8 小时前
SpringBoot项目启动时的依赖处理
java·spring boot·后端
一叶飘零_sweeeet8 小时前
深度拆解汽车制造系统设计:用 Java + 设计模式打造高扩展性品牌 - 车型动态生成架构
java·设计模式·工厂设计模式