多线程优化无效(其中一个线程执行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 实际基本应用

相关推荐
审判长烧鸡14 小时前
PostgreSQL之索引/函数/触发器
数据库·postgresql·触发器·函数·索引
Data_Journal14 小时前
如何使用cURL更改User Agent
大数据·服务器·前端·javascript·数据库
掌心向暖RPA自动化14 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭14 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
Python私教14 小时前
GenericAgent PySide6 桌面应用深度解析:悬浮按钮 + 聊天面板的原生 Qt 方案
开发语言·数据库·qt
byoass14 小时前
企业云盘与设计软件深度集成:AutoCAD/Revit/SolidWorks插件开发与API集成实战
服务器·网络·数据库·安全·oracle·云计算
TeamDev15 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
爬山算法15 小时前
MongoDB(113)如何使用第三方工具进行MongoDB监控?
数据库·mongodb
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试