草庐IT

关于sql server:SQL Count Running Total in a single column

codeneng 2023-03-28 原文

SQL Count + Running Total in a single column

我对 SQL 还很陌生,所以请多多包涵。
我有一个带有日期列 (Date) 和计数列 (Count)

的表 (DataTable)

  • 2015 年 1 月 1 日 10
  • 2015 年 1 月 2 日 9
  • 2015 年 1 月 3 日 12
  • 2015 年 1 月 4 日 7
  • 2015 年 1 月 5 日 8
  • 2015 年 1 月 6 日 10
  • 2015 年 1 月 7 日 10
  • 2015 年 1 月 8 日 8
  • 2015 年 1 月 9 日 9
  • 2015 年 1 月 10 日 10
  • 2015 年 1 月 11 日 11
  • 2015 年 1 月 12 日 11

我需要创建一个新表来计算:计数、运行总计、运行财政年度、运行 12 个月。然后将这些全部添加到一个列中,并添加一个新的类别列,将这些总和按"月"、"合同日期"、"财政年度"和"12 个月到月底"分开。

  • 月份显示该月的计数
  • 迄今为止的合同就像从开始日期到结束日期的运行总计
  • 财政年度从 6 月开始,就像一个运行总计,直到它到达下一年的 5 月,之后即将到来的 6 月重置其计数
  • 到月底的 12 个月将前 11 个月添加到当前月份
  • 结果将是

    • 2015 年 1 月 1 日 10 个月
    • 2015 年 1 月 2 日 9 个月
    • 2015 年 1 月 3 日 12 个月
    • 2015 年 1 月 4 日 7 个月
    • 2015 年 1 月 5 日 8 个月
    • 2015 年 1 月 6 日 10 个月
    • 01/07/2015 10 个月
    • 2015 年 1 月 8 日 8 个月
    • 2015 年 1 月 9 日 9 个月
    • 2015 年 1 月 10 日 10 个月
    • 2015 年 1 月 11 日 11 个月
    • 2015 年 1 月 12 日 11 个月
    • 01/01/2015 10 合同至今
    • 2015 年 1 月 2 日 19 合同至今
    • 01/03/2015 31 合同至今
    • 01/04/2015 39 合同至今
    • 01/05/2015 47 合同至今
    • 2015 年 1 月 6 日 57 合同至今
    • 01/07/2015 67 合同至今
    • 2015 年 1 月 8 日 75 合同至今
    • 2015 年 1 月 9 日 84 合同至今
    • 2015 年 1 月 10 日 94 合同至今
    • 2015 年 1 月 11 日 105 合同至今
    • 2015 年 1 月 12 日 116 合同至今
    • 等等

    我将如何在一个查询中对这一切进行编程(无需创建 4 个单独的表)
    我需要使用 SQL Server Management Studio 2008 或 2008r2
    据我所知:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT * INTO DataTableFinal FROM (
    SELECT DATE, COUNT
    FROM DataTable
    UNION ALL
    SELECT DATE, COUNT = SUM (COUNT) OVER (ORDER BY DATE ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW)
    FROM DataTable
    UNION ALL
    SELECT DATE, COUNT =
    FROM DataTable
    UNION ALL
    SELECT DATE, COUNT =
    FROM DataTable
    ) AS tmp

    • 您使用的是哪个数据库?
    • SQL Server 管理工作室 2008


    我不认为 sql server 2008 在窗口函数中支持 sum()order by。试试这样的

    1
    2
    3
    4
    5
    6
    7
    8
    SELECT dates,[COUNT],'MOnth'
    FROM   Yourtable
    UNION ALL
    SELECT dates,run,'Contract to Date'
    FROM   Yourtable a
           CROSS apply (SELECT SUM([COUNT])
                        FROM   Yourtable  b
                        WHERE  a.dates >= b.dates) cs (run)

    SQLFIDDLE 演示

    • 谢谢你的工作,我已经设法让 12 个月的工作结束日期,但我似乎无法弄清楚财政年度(澳大利亚从 6 月开始)


    最终结果:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    SELECT dates,[COUNT],'Month'                    
    FROM   Yourtable                    
    UNION ALL                  
    SELECT dates,cnt,'Contract to Date'                
    FROM   Yourtable a                  
        CROSS apply (SELECT SUM([COUNT])            
            FROM   Yourtable b
            WHERE  a.dates >= b.dates) cs (cnt)
    UNION ALL                  
    SELECT dates,cnt,'12 Months to End Date'                    
    FROM   Yourtable a                  
        CROSS apply (SELECT SUM([COUNT])            
        FROM   Yourtable b
        WHERE  a.dates >= b.dates AND b.dates >= DATEADD(MONTH, -12, a.dates)) cs (cnt)
    UNION ALL                  
    SELECT dates,cnt,'Financial Year'                  
    FROM   Yourtable a                  
        CROSS apply (SELECT SUM([COUNT])            
            FROM   Yourtable b
            WHERE  a.dates >= b.dates AND b.dates >= DATEADD(YEAR,DATEDIFF(MONTH,'19100701',a.dates)/12,'19100701')) cs (cnt)

    有关关于sql server:SQL Count Running Total in a single column的更多相关文章

    1. ruby-on-rails - 关于 Ruby 的一般问题 - 2

      我在我的rails应用程序中安装了来自github.com的acts_as_versioned插件,但有一段代码我不完全理解,我希望有人能帮我解决这个问题class_eval我知道block内的方法(或任何它是什么)被定义为类内的实例方法,但我在插件的任何地方都找不到定义为常量的CLASS_METHODS,而且我也不确定是什么here,并且有问题的代码从lib/acts_as_versioned.rb的第199行开始。如果有人愿意告诉我这里的内幕,我将不胜感激。谢谢-C 最佳答案 这是一个异端。http://en.wikipedia

    2. ruby - 我怎样才能更好地了解/了解更多关于 Ruby 的知识? - 2

      按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?

    3. ruby - 关于 Ruby 中 Dir[] 和 File.join() 的混淆 - 2

      我在Ruby中遇到了一个关于Dir[]和File.join()的简单程序,blobs_dir='/path/to/dir'Dir[File.join(blobs_dir,"**","*")].eachdo|file|FileUtils.rm_rf(file)ifFile.symlink?(file)我有两个困惑:首先,File.join(@blobs_dir,"**","*")中的第二个和第三个参数是什么意思?其次,Dir[]在Ruby中有什么用?我只知道它等价于Dir.glob(),但是,我对Dir.glob()确实不是很清楚。 最佳答案

    4. elasticsearch源码关于TransportSearchAction【阶段三】 - 2

      1.回顾.TransportServicepublicclassTransportServiceextendsAbstractLifecycleComponentTransportService:方法:1publicfinalTextendsTransportResponse>voidsendRequest(finalTransport.Connectionconnection,finalStringaction,finalTransportRequestrequest,finalTransportRequestOptionsoptions,TransportResponseHandlerT>

    5. 关于Qt程序打包后运行库依赖的常见问题分析及解决方法 - 2

      目录一.大致如下常见问题:(1)找不到程序所依赖的Qt库version`Qt_5'notfound(requiredby(2)CouldnotLoadtheQtplatformplugin"xcb"in""eventhoughitwasfound(3)打包到在不同的linux系统下,或者打包到高版本的相同系统下,运行程序时,直接提示段错误即segmentationfault,或者Illegalinstruction(coredumped)非法指令(4)ldd应用程序或者库,查看运行所依赖的库时,直接报段错误二.问题逐个分析,得出解决方法:(1)找不到程序所依赖的Qt库version`Qt_5'

    6. ruby - 关于 Ruby/ChefSpec 编码风格的反馈 - 2

      我是Ruby的新手,但过去两周我一直在对Chef测试进行大量研究。该测试使用ChefSpec和Fauxhai,但它看起来不是很“像ruby”,我希望社区能给我一些编码风格的建议。有没有更好的方法来编写这样的嵌套循环?Recipe/foo/recipes/default.rbpackage"foo"doaction:installendRecipe/foo/spec/default_spec.rbrequire'chefspec'describe'foo::default'doplatforms={"debian"=>['6.0.5'],"ubuntu"=>['12.04','10.04

    7. ruby - 关于 ruby​​ 类变量的困惑 - 2

      假设一个使用类变量的简单ruby​​程序,classHolder@@var=99defHolder.var=(val)@@var=valenddefvar@@varendend@@var="toplevelvariable"a=Holder.newputsa.var我猜结果应该是99,但输出不是99。我想知道为什么。由于类变量的范围是类,我假设@@var="toplevelvariable"行不会影响类中的变量。 最佳答案 @@var是Holder的类变量。而顶层的@@var不是Holder的同名类变量@@var,是你在创建类Obj

    8. 一文解决关于VLAN所有的疑惑 - 2

      一文解决关于VLAN所有的疑惑VLAN基本概念为什么需要VLAN?怎么在交换机上划分VLAN,VLAN的工作原理有了子网,已经隔离了广播,还需要VLAN干啥?只进行子网划分,不进行VLAN划分VLAN划分与子网划分附加VLAN信息的方法VLAN划分交换机的端口类型(Access和Trunk)一、访问链接二、汇聚链接汇聚链接VLAN间通信为什么要进行VLAN间通信?路由器实现VLAN间通信路由器和交换机的连接方式通信细节三层交换机实现VLAN间通信加速VLAN间通信三层交换机与路由器三层交换机路由器路由器和交换机配合构建LAN的实例使用VLAN设计局域网的特点VLAN增加网络的灵活性不使用VLA

    9. ruby - 关于 CoffeeScript 变量范围的困惑 - 2

      我正在尝试了解CoffeeScript变量的范围。根据文档:ThisbehavioriseffectivelyidenticaltoRuby'sscopeforlocalvariables.但是,我发现它的工作方式不同。在CoffeeScript中a=1changeValue=->a=3changeValue()console.log"a:#{a}"#Thisdisplays3在ruby中a=1deffa=3endputsa#Thisdisplays1有人能解释一下吗? 最佳答案 Ruby的局部变量(以[a-z_]开头)arerea

    10. 关于yolov5训练时参数workers和batch-size的理解 - 2

      关于yolov5训练时参数workers和batch-size的理解yolov5训练命令workers和batch-size参数的理解两个参数的调优总结yolov5训练命令python.\train.py--datamy.yaml--workers8--batch-size32--epochs100yolov5的训练很简单,下载好仓库,装好依赖后,只需自定义一下data目录中的yaml文件就可以了。这里我使用自定义的my.yaml文件,里面就是定义数据集位置和训练种类数和名字。workers和batch-size参数的理解一般训练主要需要调整的参数是这两个:workers指数据装载时cpu所使

    随机推荐