如何统计全天各个时间段产品销量情况(sqlserver)

数据库环境:SQL SERVER 2005

现有一个产品销售实时表,表数据如下:

字段name是产品名称,字段type是销售类型,1表示售出,2表示退货,字段num是数量,字段ctime是操作时间。

要求:

  在一行中统计24小时内所有货物的销售(售出,退货)数据,把日期考虑在内。

分析:

  这实际上是行转列的一个应用,在进行行转列之前,需要补全24小时的所有数据。补全数据可以通过系统的数字辅助表

spt_values来实现,进行行转列时,根据type和处理后的ctime分组即可。

1.建表,导入数据

CREATE TABLE snake (name VARCHAR(10 ),type INT,num INT, ctime DATETIME )
INSERT INTO snake VALUES(' 方便面', 1,10 ,'2015-08-10 16:20:05')
INSERT INTO snake VALUES(' 香烟A ', 2,2 ,'2015-08-10 18:21:10')
INSERT INTO snake VALUES(' 香烟A ', 1,5 ,'2015-08-10 20:21:10')
INSERT INTO snake VALUES(' 香烟B', 1,6 ,'2015-08-10 20:21:10')
INSERT INTO snake VALUES(' 香烟B', 2,9 ,'2015-08-10 20:21:10')
INSERT INTO snake VALUES(' 香烟C', 2,9 ,'2015-08-10 20:21:10')

2.补全24小时的数据

/*枚举0-23自然数列*/
WITH  x0
     AS ( SELECT  number AS h
        FROM   master..spt_values
        WHERE  type = 'P'
            AND number >= 0
            AND number <= 23
       ),/*找出表所有的日期*/
    x1
     AS ( SELECT DISTINCT
            CONVERT(VARCHAR(100), ctime, 23) AS d
        FROM   snake
       ),/*补全所有日期的24小时*/
    x2
     AS ( SELECT  x1.d ,
            x0.h
        FROM   x1
            CROSS JOIN x0
       ),
    x3
     AS ( SELECT  name ,
            type ,
            num ,
            DATEPART(hour, ctime) AS h
        FROM   snake
       ),/*整理行转列需要用到的数据*/
    x4
     AS ( SELECT  x2.d ,
            x2.h ,
            x3.name ,
            x3.type ,
            x3.num
        FROM   x2
            LEFT JOIN x3 ON x3.h = x2.h
       )

3.行转列

SELECT ISNULL([0], 0) AS [00] ,
      ISNULL([1], 0) AS [01] ,
      ISNULL([2], 0) AS [02] ,
      ISNULL([3], 0) AS [03] ,
      ISNULL([4], 0) AS [04] ,
      ISNULL([5], 0) AS [05] ,
      ISNULL([6], 0) AS [06] ,
      ISNULL([3], 7) AS [07] ,
      ISNULL([8], 0) AS [08] ,
      ISNULL([9], 0) AS [09] ,
      ISNULL([10], 0) AS [10] ,
      ISNULL([3], 11) AS [11] ,
      ISNULL([12], 0) AS [12] ,
      ISNULL([13], 0) AS [13] ,
      ISNULL([14], 0) AS [14] ,
      ISNULL([3], 15) AS [15] ,
      ISNULL([16], 0) AS [16] ,
      ISNULL([17], 0) AS [17] ,
      ISNULL([18], 0) AS [18] ,
      ISNULL([19], 15) AS [19] ,
      ISNULL([20], 0) AS [20] ,
      ISNULL([21], 0) AS [21] ,
      ISNULL([22], 0) AS [22] ,
      ISNULL([23], 15) AS [23] ,
      type ,
      d AS date
  FROM  ( SELECT  d ,
            h ,
            type ,
            num
       FROM   x4
      ) t PIVOT( SUM(num) FOR h IN ( [0], [1], [2], [3], [4], [5], [6],
                      [7], [8], [9], [10], [11], [12],
                      [13], [14], [15], [16], [17], [18],
                      [19], [20], [21], [22], [23] ) ) t
  WHERE  type IS NOT NULL

来看一下最终效果,只有1天的数据,可能看起来不是很直观。

本文的技术点有2个:

  1.利用数字辅助表补全缺失的记录

  2.pivot行转列函数的使用

以上内容是如何统计全天各个时间段产品销量情况(sqlserver)的全部内容,希望大家喜欢。

(0)

相关推荐

  • SQLSERVER收集语句运行的统计信息并进行分析

    对于语句的运行,除了执行计划本身,还有一些其他因素要考虑,例如语句的编译时间.执行时间.做了多少次磁盘读等. 如果DBA能够把问题语句单独测试运行,可以在运行前打开下面这三个开关,收集语句运行的统计信息. 这些信息对分析问题很有价值. 复制代码 代码如下: SET STATISTICS TIME ON SET STATISTICS IO ON SET STATISTICS PROFILE ON SET STATISTICS TIME ON ----------------------------

  • SQLSERVER语句的执行时间显示的统计结果是什么意思

    在SQL语句调优的时候,大部分都会查看语句执行时间,究竟SQLSERVER显示出来的统计结果是什么意思? 下面看一下例子 比较简单的语句: 复制代码 代码如下: 1 SET STATISTICS TIME ON 2 USE [pratice] 3 GO 4 SELECT * FROM [dbo].[Orders] 结果: 复制代码 代码如下: SQL Server 分析和编译时间: CPU 时间 = 0 毫秒,占用时间 = 0 毫秒. SQL Server 执行时间: CPU 时间 = 0 毫秒

  • sqlserver 统计sql语句大全收藏

    1.计算每个人的总成绩并排名 select name,sum(score) as allscore from stuscore group by name order by allscore 2.计算每个人的总成绩并排名 select distinct t1.name,t1.stuid,t2.allscore from stuscore t1,( select stuid,sum(score) as allscore from stuscore group by stuid)t2where t1

  • SQLServer2005 中的几个统计技巧

     在SQLServer中我们可以用over子句中来代替子查询实现来提高效率,over子句除了排名函数之外也可以和聚合函数配合.实现代码如下: 复制代码 代码如下: use tempdb go if (object_id ('tb' ) is not null ) drop table tb go create table tb (name varchar (10 ), val int ) go insert into tb select 'aa' , 10 union all select 'a

  • SQLserver 实现分组统计查询(按月、小时分组)

    设置AccessCount字段可以根据需求在特定的时间范围内如果是相同IP访问就在AccessCount上累加. 复制代码 代码如下: Create table Counter ( CounterID int identity(1,1) not null, IP varchar(20), AccessDateTime datetime, AccessCount int ) 该表在这儿只是演示使用,所以只提供了最基本的字段 现在往表中插入几条记录 insert into Counter selec

  • 如何统计全天各个时间段产品销量情况(sqlserver)

    数据库环境:SQL SERVER 2005 现有一个产品销售实时表,表数据如下: 字段name是产品名称,字段type是销售类型,1表示售出,2表示退货,字段num是数量,字段ctime是操作时间. 要求: 在一行中统计24小时内所有货物的销售(售出,退货)数据,把日期考虑在内. 分析: 这实际上是行转列的一个应用,在进行行转列之前,需要补全24小时的所有数据.补全数据可以通过系统的数字辅助表 spt_values来实现,进行行转列时,根据type和处理后的ctime分组即可. 1.建表,导入数

  • Python模拟登陆淘宝并统计淘宝消费情况的代码实例分享

    支付宝十年账单上的数字有点吓人,但它统计的项目太多,只是想看看到底单纯在淘宝上支出了多少,于是写了段脚本,统计任意时间段淘宝订单的消费情况,看那结果其实在淘宝上我还是相当节约的说. 脚本的主要工作是模拟了浏览器登录,解析"已买到的宝贝"页面以获得指定的订单及宝贝信息. 使用方法见代码或执行命令加参数-h,另外需要BeautifulSoup4支持,BeautifulSoup的官方项目列表页:https://www.crummy.com/software/BeautifulSoup/bs4

  • SQL 实现某时间段的统计业务

    有一张错误上报表,下面只将与本文相关的字段罗列如下:上报人(ReportPerson).上报错误ID(ErrorID).上报时间(ReportTime).状态(State),其中值为0(未解决).1(已处理).2(已解决). 现在要做的是统计在某个时间段[beginTime,endTime](其中beginTime,endTime由前台进行传入)内,每个上报人上报错误点的总数以及已解决错误的总数. 复制代码 代码如下: select a.ReportPerson,a.sumOfError,b.s

  • 微信小程序数据统计和错误统计的实现方法

    某些情况下我们需要对小程序某些用户的行为进行数据进行统计,比如统计某个页面的UV, PV等,统计某个功能的使用情况等.好让产品对于产品的整个功能有所了解. 在网页里,我们很多人都用过谷歌统计,小程序里也有一些第三方数据统计的库, 比如腾讯的MTA等等. 但是,第三方的数据统计库要么功能太简单,满足不了需求,要么就是要收费.(留下了贫穷的泪水.) 等等,又不是你出钱,怕啥? 贵一点就贵一点呀. 嗯,说的没错.但是,公司团队内部想实现一套完整的自己的数据统计系统以满足自己的需求.所以,还是没有用第三

  • javascript实现点击商品列表checkbox实时统计金额的方法

    本文实例讲述了javascript实现点击商品列表checkbox实时统计金额的方法.分享给大家供大家参考.具体实现方法如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999

  • iOS利用Runtime实现友盟页面数据统计的功能示例

    前言 一般项目中集成统计功能随因产品类型不同而使用功能不同,但大多数统计一般只有一个目的,就是记录用户习惯,研究用户习惯,从而为用户带来更好的体验,本文主要介绍了关于iOS用Runtime实现友盟页面数据统计功能的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. 一.概念 1.实现页面的统计,需要在每一个类中实现这个方法: - (void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; [

  • python实战之实现excel读取、统计、写入的示例讲解

    背景 图像领域内的一个国内会议快要召开了,要发各种邀请邮件,之后要录入.统计邮件回复(参会还是不参会等).如此重要的任务,老师就托付给我了.ps: 统计回复邮件的时候,能知道谁参会或谁不参会. 而我主要的任务,除了录入邮件回复,就是统计理事和普通会员的参会情况了(参会的.不参会的.没回复的).录入邮件回复信息没办法只能人工操作,但如果统计也要人工的话,那工作量就太大了(比如在上百人的列表中搜索另外上百人在不在此列表中!!),于是就想到了用python来帮忙,花两天时间不断修改,写了6个版本...

  • Python爬取阿拉丁统计信息过程图解

    背景 目前项目在移动端上,首推使用微信小程序.各项目的小程序访问数据有必要进行采集入库,方便后续做统计分析.虽然阿拉丁后台也提供了趋势分析等功能,但一个个的获取数据做数据分析是很痛苦的事情.通过将数据转换成sql持久化到数据库上,为后面的数据分析和展示提供了基础. 实现思路 阿拉丁产品分开放平台和统计平台两个产品线,目前开放平台有api及配套的文档.统计平台api需要收费,而且贼贵.既然没有现成的api可以获取数据,那么我们尝试一下用python抓取页面上的数据,毕竟python擅长干这种事情.

  • springboot基于过滤器实现接口请求耗时统计操作

    Spring Boot中实现一个过滤器相当简单,实现javax.servlet.Filter接口即可. 下面以实现一个记录接口访问日志及请求耗时的过滤器为例: 1.定义ApiAccessFilter类,并实现Filter接口 @Slf4j @WebFilter(filterName = "ApiAccessFilter", urlPatterns = "/*") public class ApiAccessFilter implements Filter { @Ov

  • redis统计APP在线人数的实例

    最近有个需求,需要统计APP的在线人数,其实以前也统计过,采取的是上线发送一个请求$this->cache->incr()加1,下线的时候$this->cache->decr()减1,可是这样做的后果是,发现在线人数错的离谱,几千人同是在线. why?原来APP端如果卸载的时候,那么就不会发请求,还有如果非正常终止的时候,也不会发送下线请求? 于是乎找一个准备的统计方式 1:客户端十分钟发送一次请求,带上序列号,服务器端set('前缀.序列号',过期时间),然后服务器端统计 key

随机推荐