位置: 编程技术 - 正文

sql server如何利用开窗函数over()进行分组统计(sql server如何操作)

编辑:rootadmin

推荐整理分享sql server如何利用开窗函数over()进行分组统计(sql server如何操作),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sql server如何操作,sql server2016怎么用,sql server2017怎么用,sql serverlike,sql serverlike,sql server 怎么用,sql server 怎么用,sql server怎么使用sql语句,内容如对您有帮助,希望把文章链接给更多的朋友!

这是一道常见的面试题,在实际项目中经常会用到。

需求:求出以产品类别为分组,各个分组里价格最高的产品信息。

实现过程如下:

--测试数据

--做法一:找到每个组里,价格最大的值;然后再找出每个组里价格等于这个值的--缺点:要进行一次join

--做法二:利用over(),将统计信息计算出来,然后直接筛选结果集。--over() 可以让函数(包括聚合函数)与行一起输出。

--over() 的语法为:over([patition by ] <order by >)。需要注意的是,over() 前面是一个函数,如果是聚合函数,那么order by 不能一起使用。--over() 的另一常用情景是与 row_number() 一起用于分页。

现在来介绍一下开窗函数。

窗口函数OVER()指定一组行,开窗函数计算从窗口函数输出的结果集中各行的值。

开窗函数不需要使用GROUP BY就可以对数据进行分组,还可以同时返回基础行的列和聚合列。

1.排名开窗函数

sql server如何利用开窗函数over()进行分组统计(sql server如何操作)

ROW_NUMBER、DENSE_RANK、RANK、NTILE属于排名函数。

排名开窗函数可以单独使用ORDER BY 语句,也可以和PARTITION BY同时使用。

PARTITION BY用于将结果集进行分组,开窗函数应用于每一组。

ODER BY 指定排名开窗函数的顺序。在排名开窗函数中必须使用ORDER BY语句。

例如查询每个雇员的定单,并按时间排序

窗口函数根据PARTITION BY语句按雇员ID对数据行分组,然后按照ORDER BY 语句排序,排名函数ROW_NUMBER()为每一组的数据分从1开始生成一个序号。

ROW_NUMBER()为每一组的行按顺序生成一个唯一的序号

RANK()也为每一组的行生成一个序号,与ROW_NUMBER()不同的是如果按照ORDER BY的排序,如果有相同的值会生成相同的序号,并且接下来的序号是不连序的。例如两个相同的行生成序号3,那么接下来会生成序号5。

DENSE_RANK()和RANK()类似,不同的是如果有相同的序号,那么接下来的序号不会间断。也就是说如果两个相同的行生成序号3,那么接下来生成的序号还是4。

NTILE (integer_expression) 按照指定的数目将数据进行分组,并为每一组生成一个序号。

2.聚合开窗函数

很多聚合函数都可以用作窗口函数的运算,如SUM,AVG,MAX,MIN。

聚合开窗函数只能使用PARTITION BY子句或都不带任何语句,ORDER BY不能与聚合开窗函数一同使用。

例如,查询雇员的定单总数及定单信息

如果窗口函数不使用PARTITION BY 语句的话,那么就是不对数据进行分组,聚合函数计算所有的行的值。

标签: sql server如何操作

本文链接地址:https://www.jiuchutong.com/biancheng/312899.html 转载请保留说明!

上一篇:SQLServer行列互转实现思路(聚合函数)(sql 行列转换)

下一篇:实例讲解sql server排名函数DENSE_RANK的用法(王凤林阴盘奇门实例讲解)

  • 已申报税额是什么意思,要交吗
  • 小规模30万免税包括30万吗
  • 一般纳税人的进销项税怎么做分录
  • 税务结清后多少时间内工商需要注销
  • 公司提供午餐的目的
  • 个税补缴纳
  • 价税分离合同印花税的计税依据怎么算
  • 建筑业属于货物行业吗
  • 已经作为损失的资产以后纳税年度收回的会计处理
  • 残保金申报工资应该是实发数吗
  • 管理费用 结转
  • 政府奖励金怎么用
  • 购进客房用品取得增值税专用发票注明税额9120
  • 政府补贴项目账务怎么做
  • 水资源税改革试点实施情况
  • 预付材料款的会计分录怎么写
  • 一般纳税人的含税收入怎么算
  • 工资低于3000要申报吗
  • 营改增后填用作废的发票可以用来报销吗?
  • 一般纳税人有按季申报的吗
  • 季度申报所得税是按累计上缴吗
  • 无形资产入账价值包括注册费吗
  • 辞退员工会计分录
  • 仓库存在不足
  • windows7如何删除软件
  • 职业病治疗费用由谁来承担
  • 计提劳务派遣人数怎么算
  • 在公司发明的东西专利权归谁
  • 如何选择一款适合自己家庭的凉席
  • php file_append
  • 免税和免征增值税是一个意思么
  • 存货损失是指什么
  • 企业合并发生的交易费用
  • wordpress批量生成文章
  • 融资租赁租车
  • dedecms分页标签
  • 预收的贷方余额表示什么
  • 同一控制下企业合并发生的审计费用计入
  • 开票资料更改
  • 政府会计的会计要素有哪几个?会计要素之间的关系如何?
  • 企业账户在银行买黄金可以开发票吗
  • 企业所得税余额为负数
  • 小规模纳税人季报需要报什么
  • 收到的货款比实际货款多
  • 公司账户转账转错了能退回来吗
  • 机动车销售折让红字信息表
  • 商标的使用权
  • 委托方和受委托方的法律关系
  • 装修公司开劳务发票会被罚款吗
  • 公司收到赔偿款要交增值税吗
  • 票据粘贴处怎么粘
  • 服装销售怎么做
  • 外账会计做什么
  • 会计及库管岗位职责(要求)
  • 结账时应当结出每个账户的期末余额对吗
  • 检查sql脚本语法
  • XP系统怎么设置双屏幕
  • VMware虚拟机中安装MATE桌面环境
  • 重装win8系统后没有声音
  • linux c命令
  • centos5.4 安装
  • mac如何中文输入法
  • Linux中RedHat CentOS Ubuntu Fedora的区别详解
  • win7 64位旗舰版设置插上耳机就能播放声音拔下耳机就自动禁音方法
  • codeblocks视频教程
  • text date excel
  • jquery对动态生成的进行操作
  • shell脚本语句
  • shutdown命令不能运行
  • javascript常用函数大全
  • JavaScript 事件对象介绍
  • jquery defaultvalue
  • 【Rayeager PX2分享】OpenCV入门之线段检测
  • android获取网络数据
  • 医院体检怎么拿发票
  • 税收效应分析供求曲线
  • 陕西省国家励志奖学金证书查询入口
  • 2020百望税控盘最新系统
  • 讨论如何做好寺庙管理服务工作
  • epc项目不接受联合体投标违规吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设