mysql慢sql问题修复

突发系统某定时任务一直未执行成功,一开始用几百条数据做测试发现无反应,后续改为1条数据发现仍无反应。
问题sql:

复制代码
select * from fnd_items_itf fii
        where fii.ID in
              (
                  select max(f.ID) from fnd_items_itf f
                  where FLAG_MESSAGE = #{flagMessage}
                    and FINISHED_FLAG = 'N'
                  group by f.INVENTORY_ITEM_ID, f.organization_id
              )

1条数据执行上述sql,运行时间大概10分钟左右。

优化后sql:

复制代码
SELECT
            *
        FROM
            fnd_items_itf fii
        WHERE
                fii.ID IN (
                SELECT
                    s.*
                FROM
                    (
                        SELECT
                            max( f.ID )
                        FROM
                            fnd_items_itf f
                        WHERE
                            f.FLAG_MESSAGE = #{flagMessage}
                          AND f.FINISHED_FLAG = 'N'
                        GROUP BY
                            f.INVENTORY_ITEM_ID,
                            f.organization_id
                    ) s
            )

group by和max函数均对fii.id 关联下推有 误导,导致mysql内核执行慢。

相关推荐
暮色驶过苍茫4 分钟前
H2 与高斯数据库兼容性解决方案:虚拟表与类型处理
数据库·oracle
zm14 分钟前
多客户端-服务器(select,poll)
网络·数据库
愿你天黑有灯下雨有伞1 小时前
从数据库到播放器:Java视频续播功能完整实现解析
java·数据库·音视频
鲁子狄2 小时前
[笔记] 动态 SQL 查询技术解析:构建灵活高效的企业级数据访问层
java·spring boot·笔记·sql·mysql·mybatis
中文很快乐2 小时前
postgreSQL的sql语句
数据库·sql·postgresql
DBWYX2 小时前
Doris
数据库
Dubhehug3 小时前
8.数据库索引
数据库·mysql·索引·索引分类·索引优缺点
冬夜戏雪3 小时前
阿里云ubuntu安装mysql docker容器(拉,运行,测试完整版)
mysql·ubuntu·阿里云
满分观察网友z3 小时前
告别CRUD Boy!SQL子查询:从头疼到真香的进化之路
数据库·后端
楼兰胡杨3 小时前
MySQL 更新字段的值为当前最大值加1
mysql