位置: 编程技术 - 正文

巧妙利用PARTITION分组排名递增特性解决合并连续相同数据行(巧妙利用谐音的广告语)

编辑:rootadmin

推荐整理分享巧妙利用PARTITION分组排名递增特性解决合并连续相同数据行(巧妙利用谐音的广告语),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:巧妙利用形式是什么三字俗语,巧妙利用形势的人三字俗语,巧妙利用旧床改造,巧妙利用旧床改造,巧妙利用形式是什么三字俗语,巧妙利用旧床改造,巧妙利用柱子做设计,在品牌设计中,大创意的巧妙利用,内容如对您有帮助,希望把文章链接给更多的朋友!

问题提出

先造一些测试数据以说明题目:

数据说明,ID列连续自增,列1和列2都是TFS中PBI的状态记录,就是从什么变更到什么,如新建到批准,批准到提交神马的

现在要求连续且相同的状态变更记录合并,不连续或者不同的状态变更保留,例如:

以上图为例,ID为1,4,5,6的记录都是从New到Approved状态,但是记录1与记录4、5、6不相邻,或者说不连续,那么就要分成两组,

记录1一组,记录4、5、6一组,其它记录因为状态变更不相同所以全部保留,最后的查询结果应该长成下图这个样子:

继续之前你可以先自己试下,这可能会带来新的解题思路,

解题思路

巧妙利用PARTITION分组排名递增特性解决合并连续相同数据行(巧妙利用谐音的广告语)

该问题的关键在于GROUP BY会把记录1、4、5、6合并在一起,而这不符合要求,仅需要合并4、5、6,源表里没有这样一个字段可以将记录1与记录4、5、6区分开来,这是解题的关键

这里可以利用RANK函数配合使用PARTITION关键字,首先把分到一组去,同时产生一个组内排名的新字段R,这个排名R很关键,后边会用到,见下图:

RANK函数不了解的点这里

RANK函数以Col1 + Col2为分组条件,这样分成了四组,分别是New-Approved、Approved-Commited、Commited-In Progress、Approved-Removed

在New-Approved组内,记录1、4、5、6分别排名1、2、3、4;其它组内仅一条记录,在其组内排名均为1

现在制造了一个R字段,R字段标识了每条记录在其组内的排名,排名自1开始递增,

源表内ID自增,组内排名R递增,这就是解题的关键,

当连续相同的记录出现时,其ID与其排名R在同时递增,则其差值是相同的,拿到这个差值就可以很容易解决题目了,看下图:

记录4、5、6相同且连续出现,其ID与其排名在同时增长,其差值则保持不变,这里使用Col1 + Col2 + Gap作为分组条件即可将记录4、5、6合并,再取个最小ID出来,问题解决,完整脚本如下:

可是如果ID不连续时怎么办呢?这个不难,参考[MSSQL]ROW_NUMBER函数

freetds简介、安装、配置及使用介绍 什么是FreeTDS简单的说FreeTDS是一个程序库,可以实现在Linux系统下访问微软的SQL数据库!FreeTDS是一个开源(如果你喜欢可以称为自由)的程序库,是TDS

一个函数解决SQLServer中bigint 转 int带符号时报错问题 有一个需求是要在一个云监控的状态值中存储多个状态(包括可同时存在的各种异常、警告状态)使用了位运算机制在一个int型中存储。现在监控日志

SQLServer恢复表级数据详解 最近几天,公司的技术维护人员频繁让我恢复数据库,因为他们总是少了where条件,导致update、delete出现了无法恢复的后果,加上那些库都是几十G。恢

标签: 巧妙利用谐音的广告语

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

上一篇:如何使用Visual Studio 2010在数据库中生成随机测试数据(如何使用灭火器的方法)

下一篇:一个函数解决SQLServer中bigint 转 int带符号时报错问题(sql函数的作用)

  • 工商年报资产状况纳税总额怎么计算?
  • 小规模纳税人0税率发票
  • 税收优惠政策落实情况报告
  • 关税的完税价格是什么意思
  • 收据能入账抵税吗
  • 核定征收可以改查账征收吗
  • 受委托加工物资双方账务处理怎么做
  • 增值税进项没收到必须开销项怎么办?
  • 个人终止投资经营怎么办
  • 报关单增值税税单收货人更改
  • 认证后的发票可以留抵下月抵扣吗
  • 企业所得税预缴纳税申报表
  • 劳务费增值税专用发票虚开一万元怎么补救
  • 开发经济适用房是否需要缴纳土增税
  • 小规模的成本票
  • 小规模纳税人三个月做一次账
  • 职工食堂对外经营合法吗
  • 什么情况下一般纳税人可以转为小规模纳税人
  • 合并报表同一控制下和非同一控制下区别
  • 房租押金未全额缴纳
  • 银行承兑汇票付款提示期限
  • 收到生育津贴会计分录
  • 个人所得税如何退税操作步骤
  • 手工做账月末怎么结转
  • 怎么获得win10纯净版
  • 应收账款转账
  • PHP:ereg_replace()的用法_Regex正则函数
  • 住房公积金会扣税吗
  • 劳务报酬所得与经营所得
  • 外贸企业出口免抵退
  • framework启动
  • phpinfo()中Loaded Configuration File(none)的解决方法
  • 前端工程搭建
  • 大前端技术
  • php怎么加css
  • 生产企业出口退税政策
  • 模具固定资产如何核算
  • 返还教育费附加、地方教育费附加代征手续费的请示
  • pythonsorted函数的作用
  • wordpress防盗链
  • 农业用肥尽量不选择
  • sql2008用ip连接不了
  • 租金收入什么时候交房产税
  • 私车公用发票去哪个税务局开
  • 海关完税凭证如何取得
  • 生产成本制造费用结转
  • 缴纳房产税如何做账务处理
  • 母子公司可以合并吗
  • 企业法人个人贷款企业承担吧?
  • 资本性支出是什么活动
  • 开了假发票什么后果?
  • 小规模纳税人开专票需要交税吗
  • 民办非企业可以开发票吗
  • 管理费用业务招待费包括哪些
  • 个体户建账吗
  • Mysql 报Row size too large 65535 的原因及解决方法
  • mySQL中in查询与exists查询的区别小结
  • mysql修改默认端口方法
  • mysql查看使用情况
  • windows预体验版本遇到问题
  • xbox无法连接无线网络
  • Windows Server 2008网上邻居打开慢的解决
  • ubuntu怎么把软件放到桌面
  • linux安装rpm软件包的命令
  • 苹果mac太卡
  • windows打补丁后无法启动
  • 浅谈特殊儿童的融合教育论文
  • javascriptcsdn
  • css各种滤镜的应用是什么
  • jframe背景透明
  • Knockout visible绑定使用方法
  • JQuery datepicker 用法详解
  • node.js deno
  • android+
  • 深入php面向对象、模式与实践第5版 电子书
  • canvas实例
  • 严格模式的作用
  • Jquery实现$.fn.extend和$.extend函数
  • 增值税税率为6%,怎么计算税额
  • 三证合一,税号和营业执照不一样可以吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设