[20170525]分析函数first_value.txt

简介: [20170525]分析函数first_value.txt --//昨天看sql语句,发现居然分析函数first_value.我一直认为开发如果要做一些报表需要了解学习一些oracle分析函数的知识,我发现许 --//多开发这方面一篇空白.

[20170525]分析函数first_value.txt

--//昨天看sql语句,发现居然分析函数first_value.我一直认为开发如果要做一些报表需要了解学习一些oracle分析函数的知识,我发现许
--//多开发这方面一篇空白.我曾经更开发讲过,为什么自己不会一点点看书,仅仅1,2天有个大概记忆,以后在baidu,google查询就ok了.
--//可惜遇到这样的问题还是写出一些变态的sql语句,无语!!
--//通过例子说明:

1.环境:

SCOTT@book> @ &r/ver1
PORT_STRING                    VERSION        BANNER
------------------------------ -------------- --------------------------------------------------------------------------------
x86_64/Linux 2.4.xx            11.2.0.4.0     Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production

SCOTT@book> select emp.*,first_value(sal) over (partition by deptno order by sal desc) deptmax_sal  from emp ;
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO DEPTMAX_SAL
---------- ---------- --------- ---------- ------------------- ---------- ---------- ---------- -----------
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10        5000
      7782 CLARK      MANAGER         7839 1981-06-09 00:00:00       2450                    10        5000
      7934 MILLER     CLERK           7782 1982-01-23 00:00:00       1300                    10        5000
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20        3000
      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20        3000
      7566 JONES      MANAGER         7839 1981-04-02 00:00:00       2975                    20        3000
      7876 ADAMS      CLERK           7788 1987-05-23 00:00:00       1100                    20        3000
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20        3000
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30        2850
      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30        2850
      7844 TURNER     SALESMAN        7698 1981-09-08 00:00:00       1500          0         30        2850
      7654 MARTIN     SALESMAN        7698 1981-09-28 00:00:00       1250       1400         30        2850
      7521 WARD       SALESMAN        7698 1981-02-22 00:00:00       1250        500         30        2850
      7900 JAMES      CLERK           7698 1981-12-03 00:00:00        950                    30        2850
14 rows selected.

--//这样可以查询部门最高工资.我以前一般这样写.

SCOTT@book> select emp.*,max(sal) over (partition by deptno order by sal desc) deptmax_sal  from emp ;
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO DEPTMAX_SAL
---------- ---------- --------- ---------- ------------------- ---------- ---------- ---------- -----------
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10        5000
      7782 CLARK      MANAGER         7839 1981-06-09 00:00:00       2450                    10        5000
      7934 MILLER     CLERK           7782 1982-01-23 00:00:00       1300                    10        5000
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20        3000
      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20        3000
      7566 JONES      MANAGER         7839 1981-04-02 00:00:00       2975                    20        3000
      7876 ADAMS      CLERK           7788 1987-05-23 00:00:00       1100                    20        3000
      7369 SMITH      CLERK           7902 1980-12-17 00:00:00        800                    20        3000
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30        2850
      7499 ALLEN      SALESMAN        7698 1981-02-20 00:00:00       1600        300         30        2850
      7844 TURNER     SALESMAN        7698 1981-09-08 00:00:00       1500          0         30        2850
      7654 MARTIN     SALESMAN        7698 1981-09-28 00:00:00       1250       1400         30        2850
      7521 WARD       SALESMAN        7698 1981-02-22 00:00:00       1250        500         30        2850
      7900 JAMES      CLERK           7698 1981-12-03 00:00:00        950                    30        2850
14 rows selected.

--//使用first_value分析函数的好处可以显示别的字段,不一定是sal.
--//比如要查询显示每个部门工资最高的记录.

SCOTT@book> select * from (select emp.*,first_value(empno) over (partition by deptno order by sal desc) maxsal_empno  from emp ) where empno=MAXSAL_EMPNO;
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO MAXSAL_EMPNO
---------- ---------- --------- ---------- ------------------- ---------- ---------- ---------- ------------
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10         7839
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20         7788
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30         7698

--//我以前的写法存在一些问题,如下:
SCOTT@book> select * from (select emp.*,max(sal) over (partition by deptno order by sal desc) maxsal  from emp ) where sal=MAXSAL;
     EMPNO ENAME      JOB              MGR HIREDATE                   SAL       COMM     DEPTNO     MAXSAL
---------- ---------- --------- ---------- ------------------- ---------- ---------- ---------- ----------
      7839 KING       PRESIDENT            1981-11-17 00:00:00       5000                    10       5000
      7788 SCOTT      ANALYST         7566 1987-04-19 00:00:00       3000                    20       3000
      7902 FORD       ANALYST         7566 1981-12-03 00:00:00       3000                    20       3000
      7698 BLAKE      MANAGER         7839 1981-05-01 00:00:00       2850                    30       2850

--//这样查询部门deptno=20有2条记录.当然还有许多写法,总之开发应该抽一点点时间学习一些分析函数知识.

目录
相关文章
|
前端开发 数据安全/隐私保护
前端web入门-HTML-day02
前端web入门-HTML-day02
129 0
|
运维 双11
《阿里智能运维平台如何助力研发应对双11挑战》电子版地址
阿里智能运维平台如何助力研发应对双11挑战
138 0
《阿里智能运维平台如何助力研发应对双11挑战》电子版地址
|
分布式计算 算法 数据挖掘
KMeans算法的Mapreduce实现
在本文中我使用KMeans算法实现搜狗搜索数据集上的MapReduce程序。K-Means算法输入聚类个数k,以及源数据,并将源数据分为k类输出。在分类后的数据中,同一聚类中的对象相似度较高;而不同聚类中的对象相似度较小。
4648 0
|
4天前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1106 0
|
3天前
|
机器学习/深度学习 人工智能 前端开发
通义DeepResearch全面开源!同步分享可落地的高阶Agent构建方法论
通义研究团队开源发布通义 DeepResearch —— 首个在性能上可与 OpenAI DeepResearch 相媲美、并在多项权威基准测试中取得领先表现的全开源 Web Agent。
529 10
|
13天前
|
人工智能 运维 安全
|
12天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。
|
4天前
|
弹性计算 Kubernetes jenkins
如何在 ECS/EKS 集群中有效使用 Jenkins
本文探讨了如何将 Jenkins 与 AWS ECS 和 EKS 集群集成,以构建高效、灵活且具备自动扩缩容能力的 CI/CD 流水线,提升软件交付效率并优化资源成本。
301 0
|
11天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
12天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
807 23