news 2026/2/24 19:10:53

先过滤后关联的优化经验分享

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
先过滤后关联的优化经验分享

1、问题语句

最近遇到一个问题,发现开发人员比较喜欢单一的将表放一块一起做关联。如果有了先过滤后关联的思维,大部分语句的性能会获得提升。
以下是真实项目简化而来的例子

select * from(select a.c1,a.mid,a.bcode,c.ttime,row_number()over(partition by a.bcode order by c.ttime desc)rn from"T11"A,T12 b,t13 c where a.id1=b.id1 and a.id1=c.id1(+)and a.c1=3 and b.c1=3 and b.bcode='0300')tt where tt.rn=1;

计划:

该语句最终是获取去重后rn=1(即每组第一行)的数据,而我们分析到t13表数据量很多,这里简单的关联后再去重,性能消耗较多,而优化思路是先t11表和t12表先过滤条件和去重之后,以及t13表去重过滤后,两个小的结果集进行关联,这样性能会提升。因此根据我们的思路进行改写。

2、改写

select tt.c1,tt.mid,tt.bcode,b.ttime,rn from(select a.c1,a.mid,a.bcode,a.id1,row_number()over(partition by a.bcode order by null desc)rn from"T11"A,T12 b where a.id1=b.id1 and a.c1=3 and b.c1=3 and b.bcode='0300')tt,(selectmax(ttime)ttime,id1 from t13 group by id1)b where tt.rn=1 and tt.id1=b.id1(+);

计划:

最终性能提升了几倍,在项目中的数据较多,原本语句也复杂,改写后从原来跑20分钟,到最终秒级执行完。

3、小结

我们一般要先过滤出小结果集再关联,相当于我们先分组减去重复的部分,减少对比次数,从而提升效率。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/22 7:56:41

MiniMax的全球化之路:中国AI公司出海的新样本

MiniMax成立4年即实现73%海外收入,以Talkie、海螺AI为核心产品,凭借“生而全球化”战略,从底层架构适配全球市场,通过文化本地化运营和高效市场推广,在全球200多个国家及地区拥有2.12亿用户,为中国AI公司出…

作者头像 李华
网站建设 2026/2/17 7:14:46

2023年NOC大赛创客智慧编程赛项Python复赛模拟题(二)

更多内容和历年真题请查看网站:【试卷中心 -----> NOC ----> Python ----> 复赛】 网站链接 青少年软件编程历年真题模拟题实时更新 2023年NOC大赛创客智慧编程赛项Python复赛模拟题(二) 一、编程题 第 1 题 NOC大赛创客智慧编程…

作者头像 李华
网站建设 2026/2/18 5:24:20

SpringBoot整合Thymeleaf

一、Thymeleaf 简介Thymeleaf 是一款现代化的服务器端 Java 模板引擎,主要用于 Web 开发中渲染 HTML 页面,能够无缝集成 Spring Boot 框架。它的核心优势是:支持 HTML 原生语法,模板文件可直接在浏览器中打开预览(无后…

作者头像 李华
网站建设 2026/2/23 12:28:49

亲测好用!8个AI论文平台测评,研究生毕业论文必备

亲测好用!8个AI论文平台测评,研究生毕业论文必备 2026年AI论文平台测评:从功能到体验的深度解析 随着人工智能技术在学术领域的广泛应用,越来越多的研究生开始依赖AI工具来提升论文写作效率。然而,面对市场上五花八门的…

作者头像 李华
网站建设 2026/2/24 9:56:27

循环经济在不同行业的应用前景比较

循环经济在不同行业的应用前景比较 关键词:循环经济、行业应用、应用前景、可持续发展、资源利用 摘要:本文旨在深入探讨循环经济在不同行业的应用前景并进行比较。首先介绍了循环经济的背景知识,包括其目的、适用读者、文档结构和相关术语。接着阐述了循环经济的核心概念、…

作者头像 李华