热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SQL训练营Task05:SQL语句高阶应用窗口函数等

本笔记为阿里云天池龙珠计划SQL训练营的学习内容,链接为:https:tianchi.aliyun.comspecialspromotionaicamp

本笔记为阿里云天池龙珠计划SQL训练营的学习内容,链接为:https://tianchi.aliyun.com/specials/promotion/aicampsql

文章目录

  • 前言
  • 一、专用窗口函数
  • 二、聚类窗口函数
  • 三、task05习题及参考答案
    • 5.1
    • 5.2
    • 5.3




前言

本笔记为阿里云天池龙珠计划SQL训练营的学习内容,链接为:https://tianchi.aliyun.com/specials/promotion/aicampsql



一、专用窗口函数

窗口函数也称为OLAP函数。OLAP 是OnLine AnalyticalProcessing 的简称,意思是对数据库数据进行实时分析处理。

窗口函数的通用形式:

<窗口函数> OVER ([PARTITION BY <列名>]ORDER BY <排序用列名>)

PARTITON BY是用来分组&#xff0c;即选择要看哪个窗口&#xff0c;类似于GROUP BY 子句的分组功能&#xff0c;但是PARTITION BY子句并不具备GROUP BY 子句的汇总功能&#xff0c;并不会改变原始表中记录的行数。

ORDER BY是用来排序&#xff0c;即决定窗口内&#xff0c;是按那种规则(字段)来排序的。

专用窗口函数&#xff1a;

  • row_number() over(…)
  • rank() over(…)
  • dense_rank() over(…)

注意&#xff1a;一定是row_number()&#xff0c;rank()&#xff0c;dense_rank()&#xff0c;后面一定要有括号&#xff0c;括号里面什么都不用写

三个函数的区别如下&#xff1a;

SELECT product_name,product_type,sale_price,RANK() OVER (ORDER BY sale_price) AS ranking,DENSE_RANK() OVER (ORDER BY sale_price) AS dense_ranking,ROW_NUMBER() OVER (ORDER BY sale_price) AS row_num
FROM product

在这里插入图片描述

  • RANK函数 计算排序时&#xff0c;如果存在相同位次的记录&#xff0c;则会跳过之后的位次。

    – 例&#xff09;有 3 条记录排在第 1 位时&#xff1a;1 位、1 位、1 位、4 位……

  • DENSE_RANK函数 同样是计算排序&#xff0c;即使存在相同位次的记录&#xff0c;也不会跳过之后的位次。

    – 例&#xff09;有 3 条记录排在第 1 位时&#xff1a;1 位、1 位、1 位、2 位……

  • ROW_NUMBER函数 赋予唯一的连续位次。

    – 例&#xff09;有 3 条记录排在第 1 位时&#xff1a;1 位、2 位、3 位、4 位



二、聚类窗口函数

普通场景下&#xff0c;聚合函数往往和group by一起使用&#xff0c;但是窗口环境下&#xff0c;聚合函数也可以应用进来&#xff0c;那么此时它们就被称之为聚合类窗口函数&#xff0c;属于窗口函数的一种

  • sum()
  • count()
  • avg()
  • max()
  • min()

语法

<窗口函数> OVER (ORDER BY <排序用列名>ROWS n PRECEDING ) <窗口函数> OVER (ORDER BY <排序用列名>ROWS BETWEEN n PRECEDING AND n FOLLOWING)

PRECEDING&#xff08;“之前”&#xff09;&#xff0c; 将框架指定为 “截止到之前 n 行”&#xff0c;加上自身行

FOLLOWING&#xff08;“之后”&#xff09;&#xff0c; 将框架指定为 “截止到之后 n 行”&#xff0c;加上自身行

BETWEEN 1 PRECEDING AND 1 FOLLOWING&#xff0c;将框架指定为 “之前1行” &#43; “之后1行” &#43; “自身”


三、task05习题及参考答案

5.1


请说出针对本章中使用的product&#xff08;商品&#xff09;表执行如下 SELECT 语句所能得到的结果。
本章的product表如下
本章的product表

SELECT product_id,product_name,sale_price,MAX(sale_price) OVER (ORDER BY product_id) AS Current_max_price
FROM product

5.2


继续使用product表&#xff0c;计算出按照登记日期&#xff08;regist_date&#xff09;升序进行排列的各日期的销售单价&#xff08;sale_price&#xff09;的总额。排序是需要将登记日期为NULL> 的“运动 T 恤”记录排在第 1 位&#xff08;也就是将其看作比其他日期都早&#xff09;。

selectproduct_id,product_name,regist_date,sale_price,sum(sale_price) over(order by regist_date) as current_sum_price
from product;

5.3


思考题

  • ① 窗口函数不指定PARTITION BY的效果是什么&#xff1f;

  • ② 为什么说窗口函数只能在SELECT子句中使用&#xff1f;实际上&#xff0c;在ORDER BY 子句使用系统并不会报错。


答&#xff1a;① partition by 用来选择要看哪个窗口&#xff0c;不使用partition by是查看全局。
② 因为窗口函数是对where或者group by子句处理后的结果进行操作&#xff0c;所以窗口函数原则上只能写在select子句中&#xff0c;而不是order by。

注意&#xff1a;SQL语句的执行顺序&#xff1a;from–where–group by–having–select–order by
SQL语句的书写顺序&#xff1a;select–from–where–group by–having–order by


推荐阅读
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文介绍了九度OnlineJudge中的1002题目“Grading”的解决方法。该题目要求设计一个公平的评分过程,将每个考题分配给3个独立的专家,如果他们的评分不一致,则需要请一位裁判做出最终决定。文章详细描述了评分规则,并给出了解决该问题的程序。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • Oracle分析函数first_value()和last_value()的用法及原理
    本文介绍了Oracle分析函数first_value()和last_value()的用法和原理,以及在查询销售记录日期和部门中的应用。通过示例和解释,详细说明了first_value()和last_value()的功能和不同之处。同时,对于last_value()的结果出现不一样的情况进行了解释,并提供了理解last_value()默认统计范围的方法。该文对于使用Oracle分析函数的开发人员和数据库管理员具有参考价值。 ... [详细]
  • 本文详细介绍了Spring的JdbcTemplate的使用方法,包括执行存储过程、存储函数的call()方法,执行任何SQL语句的execute()方法,单个更新和批量更新的update()和batchUpdate()方法,以及单查和列表查询的query()和queryForXXX()方法。提供了经过测试的API供使用。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
author-avatar
2335286cc
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有