关于sql 查询性能优化的小经验

最近接到一些sql优化的任务。数据库类型:DB2

有一个长sql查询效率低,大概要几十秒,大概查询逻辑如下:

select * from tableA a where exists (select 1 from tableB b where a.id=b.id )

or exists (select 1 from tableC c where a.id=c.id );

tableA ,tableB ,tableC都是大表,数据量大,最终执行时间要几十秒,

但是把or 条件改成 union all 却可以大大提升执行效率,时间降到几秒:

select * from tableA a where exists (select 1 from tableB b where a.id=b.id )

union all

select * from tableA a where exists (select 1 from tableC c where a.id=c.id );

小结:union all 替换 or 条件, 有时候可以提高查询效率。

相关推荐
lkbhua莱克瓦242 小时前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图
heartbeat..3 小时前
零基础学 SQL:DQL/DML/DDL/DCL 核心知识点汇总(附带连接云服务器数据库教程)
java·服务器·数据库·sql
23zhgjx-zgx5 小时前
SQL注入攻击分析报告
网络·sql·ctf
heartbeat..6 小时前
SQL 常用函数大全:聚合、字符串、数值、日期、窗口函数解析
java·数据库·sql·函数
yueguangni6 小时前
性能测试里jmeter的tps和rt的区别
性能优化
千里马学框架6 小时前
性能优化:Perfetto查看app启动时间及冷热启动介绍
智能手机·性能优化·aaos·perfetto·性能·安卓framework开发·车机
Fasda123457 小时前
YOLOv10n-MAFPN:西瓜目标检测模型改进与性能优化
yolo·目标检测·性能优化
DemonAvenger7 小时前
Redis数据迁移与扩容实战:平滑扩展的技术方案
数据库·redis·性能优化
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ8 小时前
sql 如果字段为空就用另一个字段
数据库·sql
時肆4859 小时前
Linux命令创意组合大赛:管道里的魔法
开发语言·性能优化