Oracle SQL - HAVING和分析函数的执行顺序

embedded/2024/12/23 8:10:17/

分析函数是基于最终的结果集进行开窗的,所以HAVING比分析函数先执行

 ↓ 没有HAVING时,MAX(col3) over()是A2

sql">SQL> WITH subq_a AS2   (SELECT 'A' col1, 'A1' col2, 10 col33      FROM dual4    UNION ALL5    SELECT 'A' col1, 'A1' col2, -5 col36      FROM dual7    UNION ALL8    SELECT 'A' col1, 'A2' col2, 10 col39      FROM dual10    UNION ALL11    SELECT 'A' col1, 'A2' col2, -15 col312      FROM dual)13  SELECT col1, col2, SUM(col3) s_col3, MAX(col2) over() x_col214    FROM subq_a15   GROUP BY col1, col216  /COL1 COL2     S_COL3 X_COL2
---- ---- ---------- ------
A    A1            5 A2
A    A2           -5 A2

 ↓ 有HAVING时,分析函数在HAVING执行过滤后的结果集上开窗计算结果,MAX(col3) over()变成A1

sql">SQL> WITH subq_a AS2   (SELECT 'A' col1, 'A1' col2, 10 col33      FROM dual4    UNION ALL5    SELECT 'A' col1, 'A1' col2, -5 col36      FROM dual7    UNION ALL8    SELECT 'A' col1, 'A2' col2, 10 col39      FROM dual10    UNION ALL11    SELECT 'A' col1, 'A2' col2, -15 col312      FROM dual)13  SELECT col1, col2, SUM(col3) s_col3, MAX(col2) over() x_col214    FROM subq_a15   GROUP BY col1, col216  HAVING SUM (col3) > 017  /COL1 COL2     S_COL3 X_COL2
---- ---- ---------- ------
A    A1            5 A1


http://www.ppmy.cn/embedded/6432.html

相关文章

导致程序崩溃删除的地方

1. 注册日志回调函数 qInstallMessageHandler(outputMessage);解决方法 Android 环境下直接不重定向日志,经过后期调试应该是 dynamic_static 转换失败导致。 #ifndef __ANDROID__qInstallMessageHandler(outputMessage); #endif2. 单例上锁,新增了 A…

SpringBlade dict-biz/list SQL 注入漏洞复现

0x01 免责声明 请勿利用文章内的相关技术从事非法测试,由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人负责,作者不为此承担任何责任。工具来自网络,安全性自测,如有侵权请联系删…

接口压力测试 jmeter--入门篇(一)

一 压力测试的目的 评估系统的能力识别系统的弱点:瓶颈/弱点检查系统的隐藏的问题检验系统的稳定性和可靠性 二 性能测试指标以及测算 【虚拟用户数】:线程用户【并发数】:指在某一时间,一定数量的虚拟用户同时对系统的某个功…

人工智能的未来会怎样?Gartner发布AI技术成熟度曲线

对于任何人来说,生成式人工智能和支持它的基础模型目前都处于Gartner所谓的「膨胀预期的顶峰」,这一点并不奇怪,在最新的「Gartner AI技术成熟度曲线」中。这意味着他们正在悬崖上摇摇欲坠,这可能会使他们陷入「幻灭的低谷」。 「…

2024能源动力、机械自动化与航天航空技术国际学术会议(ICEPMAT2024)

2024能源动力、机械自动化与航天航空技术国际学术会议(ICEPMAT2024) 会议简介 能源动力、机械自动化和航空航天技术国际学术会议(ICEPMAT2024)将于2024年在北京举行。会议将探讨能源动力、机械自动化、航空航天技术领域的新研究热点、核心技术和发展趋…

缓存与数据库的数据一致性解决方案分析

在现代应用中,缓存技术的使用广泛且至关重要,主要是为了提高数据访问速度和优化系统整体性能。缓存通过在内存或更快速的存储系统中存储经常访问的数据副本,使得数据检索变得迅速,从而避免了每次请求都需要从较慢的主存储&#xf…

深入浅出理解CSS中的3D变换:踏上立体视觉之旅

在现代Web设计中,CSS 3D变换已经成为增强用户体验、打造沉浸式界面的重要手段。借助CSS的3D变换属性,我们可以轻松实现元素在三维空间中的旋转、移动、缩放等操作,从而创造出生动活泼、富有立体感的网页效果。本文将从基础知识出发&#xff0…

git切换源失败解决方案

git切换源失败解决方案 git切换源git切换源失败(无效) git切换源 git可以使用命令行切换源,一般使用的源有两个地址,git原生地址和淘宝镜像地址,部分公司会使用内部地址。 源切换后,npm i就是从源地址拉取相关依赖了。 原生地址…