多线程优化无效(其中一个线程执行10秒导致)

尽量避免循环写sql,row_number 实际基本应用

一、原来sql

java 复制代码
    // 原来是 t1 表和t2 表关联,查t1的code,同时要是t2 表某个属性xx 降序后取一个
    String sql ="    SELECT t1.*, t2.xx, " +
            "    FROM table1 t1 " +
            "    LEFT JOIN table2 t2 ON t1.id = t2.table1_id " +
            "    WHERE t1.code = '{}' order by t2.xx desc fetch first 1 rows only ";
//    在循环中写sql
    for(YourObject item : objectList){
        String code = item.getCode();
        Map<Stirng,Object> resultMap = getSqlMapper().selectOne(strUtil.format(sql,code));
//        查出结果继续别的处理
    }

二、优化后sql

java 复制代码
    public void processWithRowNumber(List<YourObject> objectList) {
        if (objectList.isEmpty()) return;
        
        Set<Long> codeSet = objectList.stream()
            .map(YourObject::getCode)
            .collect(Collectors.toSet());
        
        String inClause = codeSet.stream()
            .map(String::valueOf)
            .collect(Collectors.joining(","));
        
        // 使用ROW_NUMBER()为每个ID分组,取最新的一条
        String sql = "SELECT * FROM (" +
                     "    SELECT t1.*, t2.xx, " +
                     "           ROW_NUMBER() OVER (PARTITION BY t1.id ORDER BY t2.xx DESC) as rn " +
                     "    FROM table1 t1 " +
                     "    LEFT JOIN table2 t2 ON t1.id = t2.table1_id " +
                     "    WHERE t1.code IN (" + inClause + ")" +
                     ") WHERE rn = 1";
        
        List<Map<String, Object>> results = sqlMapper.selectList(sql);
        
        // 构建映射关系
        Map<Long, Map<String, Object>> resultMap = results.stream()
            .collect(Collectors.toMap(
                result -> ((Number) result.get("CODE")).longValue(),
                result -> result
            ));
        
        // 处理结果
        for (YourObject obj : objectList) {
            Map<String, Object> result = resultMap.get(obj.getCode());
            if (result != null) {
                processSingleResult(obj, result);
            }
        }
    }

三、总结

这是row_number 实际基本应用(用于优化sql放在循环外)

将sql拿出循环就是 用row_number() over()原因

之前博客记录 row_number用法 Row number 函数用法

实际项目使用过 row_number 实际基本应用

相关推荐
有一个好名字6 分钟前
力扣-从字符串中移除星号
java·算法·leetcode
zfj32115 分钟前
CyclicBarrier、CountDownLatch、Semaphore 各自的作用和用法区别
java·开发语言·countdownlatch·semaphore·cyclicbarrier
2501_9167665421 分钟前
【JVM】类的加载机制
java·jvm
Sag_ever22 分钟前
Java数组详解
java
张np23 分钟前
java基础-ConcurrentHashMap
java·开发语言
清水白石00837 分钟前
解构异步编程的两种哲学:从 asyncio 到 Trio,理解 Nursery 的魔力
运维·服务器·数据库·python
资生算法程序员_畅想家_剑魔39 分钟前
Mysql常见报错解决分享-01-Invalid escape character in string.
数据库·mysql
一嘴一个橘子1 小时前
spring-aop 的 基础使用 - 4 - 环绕通知 @Around
java
小毅&Nora1 小时前
【Java线程安全实战】⑨ CompletableFuture的高级用法:从基础到高阶,结合虚拟线程
java·线程安全·虚拟线程
冰冰菜的扣jio1 小时前
Redis缓存中三大问题——穿透、击穿、雪崩
java·redis·缓存