位置: 编程技术 - 正文

巧妙利用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函数的作用)

  • 公司给员工租的宿舍怎么交税
  • 工资用现金发放有风险吗?
  • 金蝶专业版仓库反审核怎么做
  • 发票税号不对还能报销吗
  • 个人设备投资需要交税吗
  • 减免的所得税额怎么入账
  • 应取得未取得发票
  • 购货发票属于外来原始凭证吗为什么
  • 财务离开公司需要交接哪些资料?
  • 固定资产安装完毕达到预定可使用状态
  • 增值税发票收款人和复核人可以一个人吗
  • 餐饮业个体工商户怎么交税
  • 如何确定连锁店的纳税地点?
  • 哪些外籍个人应在中国缴纳个税?
  • 年终汇算清缴怎么计算
  • 进项发票没有收到,销项已开出,成本如何结转
  • 索赔发票会计入账
  • 现金日记账有哪几种
  • 通过拍卖取得的车牌号,过期了怎么办
  • 城建税上月少计提本月怎么做账
  • 销售残次品怎么处罚
  • 票据贴现公司需要资质吗
  • 电脑桌面刷新反应迟钝
  • 固定资产进项税额怎么做账
  • 房地产开发有限公司英文
  • 电脑管家使用教程
  • 存出投资款现金流量表选什么
  • 公司员工意外险怎么买
  • 修建污水厂需要办理哪些审批
  • 企业租赁房屋怎么开发票
  • 如何利用http协议发布博客园博文评论
  • php ftp函数
  • 长期借款和实收资本
  • 泛微oa二次开发难吗
  • java多线程线程数控制在多少
  • web课程设计模板
  • id命令的哪个参数可显示用户账号的uid信息
  • ip6tables-save命令 保存ip6tables表配置
  • 自费出版违法吗
  • 没有初级会计证可以从事会计工作吗
  • 大陆工作的香港人可以开基金账户吗
  • Spring(三)-AOP
  • 公司盖厂房没有票要交税吗?
  • 公司有收入可不交社保吗
  • 微信平台的收入从哪里来
  • c#代码怎么写
  • 预提费用是应付账款吗
  • 无形资产多摊销怎么处理
  • 简易计税怎么算增值税
  • 现金短缺与溢余解析
  • 技术报酬金是什么意思
  • 银行贷款直接给钱吗
  • 发票红字怎么弄
  • 支付关税现金流放哪儿
  • 进项转出再转入
  • 总公司与分公司的关系
  • 预缴增值税扣除额用填写吗
  • 贸易融资具体包括
  • 账簿设计原则的主要内容
  • sql语句优化总结
  • win8激活点不进去
  • bios怎么调高性能
  • xp系统磁盘检查进不去
  • mac的itunes怎么下载歌曲
  • 在linux系统中添加用户的命令
  • wmiprvse.exe是什么程序
  • xp系统部分乱码解决
  • linux磁盘结构
  • windows 自启动
  • 激素六项雌二醇30
  • win10正式版多少钱
  • unity总结
  • javascript的常用数据类型
  • node.js文件流
  • js实现二叉查找树
  • jquery fadein不起作用
  • 使用SQLite数据库保存和处理数据
  • 济南高新区地税局地址
  • 1.8排量够用吗
  • 公寓土地增值税怎么算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设