当前位置: 首页 > news >正文

mysql 8.0 窗口函数 之 序号函数 与 sql server 序号函数 一样

sql server 序号函数

序号函数

  1. ROW_NUMBER() 顺序排序
  2. RANK() 并列排序,会跳过重复的序号,比如序号为1,1,3
  3. DENSE_RANK() 并列排序,不会跳过重复的序号,比如 序号为 1,1,2

语法结构

函数 over (  [ partition by 字段名1, [ 字段2,。。。字段n]  order by 字段名 ASC | DESC  ] )## 或者
函数 over 窗口名  ... ..window 窗口名  as ( [ partition by 字段名  order by 字段名  asc  |  DESC ] )### over  关键字 指定函数窗口的范围如果省略后面括号中的内容,则窗口会包含满足where 条件的所有记录,窗口函数会基于所有满足where条件的记录  **进行计算**如果over 关键字后面的括号不为空,则可以使用如下语句设置窗口窗口名:为窗口设置一个别名,用来表示窗口,  放在  sql  最后位置partition by 子句:指定窗口函数按照哪些字段进行分组。分组后,窗口函数可以在**每个分组中分别**执行。order by 子句:指定窗口函数按照哪些字段进行排序,执行排序操作使窗口函数按照排序后的数据记录的**顺序**进行编号select  RANK() over ( partition by course by  score  desc ) as 排名,stu_name
from   stu_grade#   方法2 
select  RANK() over  cnd  as 排名,stu_name
from   stu_grade
where window cnd as  ( partition by course by  score  desc ) 

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

窗口函数的优点

使用窗口函数,只用了一步就完成了查询,而且,由于没有用到临时表,执行的效率也更高了。很显然,在这种需要用到分组统计的结果对每一条记录进行计算的场景下,使用窗口函数更好

窗口函数的作用类似于在查询中对数据进行分组,不同的是,分组操作会把分组的结果聚合成一条记录,而窗口函数是将结果置于每一条数据记录中。

窗口函数可分为: ①静态窗口函数②动态窗口函数
静态窗口函数的窗口大小是固定的,不会因为记录的不同而不同
动态窗口函数的窗口大小会随着记录的不同而变化。

http://www.lryc.cn/news/139080.html

相关文章:

  • fastgpt构建镜像
  • Git笔记--分支常用命令
  • 常见设计模式学习+面试总结
  • sql解决取多个截至每个月的数据
  • 数据采集:selenium 获取 CDN 厂家各省市节点 IP
  • 【el-tree】树形组件图标的自定义
  • UltralSO软碟通制作Linux系统盘
  • yolov8训练心得 持续更新
  • 超越界限:大模型应用领域扩展,探索文本分类、文本匹配、信息抽取和性格测试等多领域应用
  • Compose - 基本使用
  • Unity3D Pico VR 手势识别
  • 【docker】运行registry
  • java八股文面试[Spring]——如何实现一个IOC容器
  • Redis 列表 | Navicat
  • 【校招VIP】测试专业课之TCP/IP模型
  • leetcode76. 最小覆盖子串(滑动窗口-java)
  • 后端项目开发:整合全局异常处理
  • Linux socket网络编程概述 和 相关API讲解
  • uni-app封装省市区下拉组件(后台获取数据)
  • laravel中Mail发送邮件失败,但是没有错误信息,该如何调试?
  • 软考高级系统架构设计师系列论文八十五:论软件产品线技术
  • More Effective C++学习笔记(4)
  • 概率密度函数 累积分布函数
  • 基于OpenCV实战(基础知识二)
  • PhantomJS+java 后端生成echart图表的图片
  • vue3 基础知识 ( webpack 基础知识)05
  • 1.4亿X区智慧城市数字平台及城市大脑(运营中心)建设项目WORD
  • wps 画项目进度甘特图
  • 【⑭MySQL | 数据类型(二)】字符串 | 二进制类型
  • Java smslib包开发