位置: 编程技术 - 正文

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的用法(王凤林阴盘奇门实例讲解)

  • 税负转嫁的概念是什么
  • 新成立公司交税
  • 中介公司报税怎么操作
  • 应付债券利息调整是什么意思
  • 纳税总额是否包含增值税进项
  • 总分机构移送固定资产是否缴增值税
  • 粮食收购发票 票样
  • 费用确认的时点
  • 库存商品采用定价法
  • 准予抵扣的进项税范围
  • 销售税金及附加含增值税吗
  • 小规模纳税人多少免征增值税
  • 其他收益是否需缴税
  • 客户充值
  • 人力资源劳务费发票税率
  • 自建厂房销售
  • 记账凭证广告费
  • 简易办法征收一般纳税人开票税率
  • 少交了增值税怎么补
  • 董事会费用计入什么科目
  • 新领的发票怎么读入开票系统
  • 怎么打印事业单位准考证
  • 土地纳税申报表
  • 其他资本公积如何花掉
  • 和别人合作投资后悔了怎么说
  • 电子发票增加开票项目
  • 营业执照原件丢失后果
  • 一般纳税人取得免税农产品进项怎么抵扣
  • 机动车抵扣联是什么
  • 关闭通知横幅
  • Win11怎么隐藏底部
  • 生育津贴报销需要准生证吗
  • 小规模纳税人缴纳增值税怎么算
  • 评估价值时点依据什么
  • 用友结转所得税费用
  • 企业的股息红利所得
  • 折旧计算表属于外来原始凭证吗
  • 现金长款怎么做会计分录
  • 融资租赁的两种基本形式
  • 预收房屋租金
  • laravel引入css
  • 加油费属于什么费用类别的
  • vue3中如何使用vuex
  • javaweb.xml配置文件
  • 购入固定资产的进项税额可以抵扣吗
  • 代开增值税发票需要预交所得税吗
  • 区块管理办法
  • 调账处理
  • 劳务外经证预缴税款
  • mybatis入门菜鸟教程
  • 小规模纳税人开具增值税专用发票
  • 个人所得税数据怎么导入新电脑
  • 公司清算的特征
  • 企业所得税的成本怎么填?
  • 发票的类型分为哪几类
  • 水利建设基金应税项是什么
  • 工商年报认缴时间过期了怎么办
  • 房地产开发结转流程
  • 防伪税控服务费计入什么科目
  • 出口抵减内销产品应纳税额分录
  • 制造费用和管理费用怎么结转
  • 百旺云票怎么开电子发票
  • linux怎么统计文件中出现字符串的数量
  • winxp资源管理器频繁无响应
  • win7主题服务未运行怎么办
  • glib库
  • nodejs爬取数据
  • setcontentview报错
  • vs提示图标的含义
  • angular指令详解
  • css回到页面顶部
  • linux shell -s
  • vuex按需加载
  • js实现兼容性较好的方法
  • Android自定义动画
  • 电子发票版式文件生成失败怎么办
  • 办理税务迁移的流程
  • 开票风险预警机制蓝色预警怎么办
  • 国家税务总局纳雍县税务局
  • 北京朝阳区国税局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设