1. 个人技术分享首页

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

数据库环境:SQL SERVER 2005

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

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

字段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 

3.行转列

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

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

本文的技术点有2个:

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

  2.pivot行转列函数的使用

文章来源于互联网:如何统计全天各个时间段产品销量情况(sqlserver)

原创文章,作者:admin,如若转载,请注明出处:https://www.aliyunsolution.com/3654.html