如何使用sqlserver统计全天各个时间段产品销量情况
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,本篇文章为大家展示了如何使用sqlserver统计全天各个时间段产品销量情况,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。现有一个产品销售实时表,表数据如下:
千家信息网最后更新 2025年11月08日如何使用sqlserver统计全天各个时间段产品销量情况
本篇文章为大家展示了如何使用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 <= 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统计全天各个时间段产品销量情况,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
数据
香烟
产品
字段
小时
时间
日期
销售
全天
情况
时间段
销量
统计
内容
技能
数字
知识
辅助
简明
直观
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库视图缺点
预算管理系统数据库结构
谷歌服务器发展历程
绵阳金惠科技互联网
思科网络技术官方用语
为什么要做公安网络安全
传奇物品数据库color
互联网高科技产业基地
问道数据库怎么删角色
社会网络安全事件
电脑网络安全配置
郑州网络安全科技馆有什么好玩的
网络安全法相关委托
序列怎么和数据库关联
无法连接lol服务器
什么时候开始网络安全审查
直销软件开发公司前10名
齐齐哈尔软件开发公司电话
西交网络安全 导师
软件开发整个学习流程
网络技术规范具有的特征是
四川最好的服务器云空间
中文科技期刊全文数据库检索规则
郑州绳木网络技术有限公司
软件工程 网络安全
财旺网络技术集团
软件开发项目进度可视化
陕西政务服务器云空间
数据库一次执行多条命令
网络安全与防护资格证