加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 如何查询获取最近七天的总数?

发布时间:2020-12-12 08:33:02 所属栏目:MsSql教程 来源:网络整理
导读:我正在使用SQL Server 2008. 我想写一个查询,给我一些给定天数的总活动.具体来说,我想计算过去七天每天的总票数. 我的表看起来像这样: VoteID --- VoteDate -------------- Vote --- BikeID 1 2012-01-01 08:24:25 1 1234 2 2012-01-01 08:24:25 0 5678 3 20
我正在使用SQL Server 2008.

我想写一个查询,给我一些给定天数的总活动.具体来说,我想计算过去七天每天的总票数.

我的表看起来像这样:

VoteID --- VoteDate --------------  Vote --- BikeID

 1          2012-01-01 08:24:25      1        1234 
 2          2012-01-01 08:24:25      0        5678
 3          2012-01-02 08:24:25      1        1289
 4          2012-01-03 08:24:25      0        1234
 5          2012-01-04 08:24:25      1        5645
 6          2012-01-05 08:24:25      0        1213
 7          2012-01-06 08:24:25      1        1234
 8          2012-01-07 08:24:25      0        1125

我需要我的结果看起来像这样

VoteDate ---- Total
2012-01-01    5
2012-01-02    6
2012-01-03    7
2012-01-04    1
2012-01-05    3

我的想法是我必须做这样的事情:

SELECT    SUM(CASE WHEN Vote = 1 THEN 1 ELSE 0 END) AS Total
FROM      Votes
GROUP BY  VoteDate

此查询不起作用,因为它只计算同时发生(几乎完全)的投票.当然,我想只关注某一天.我该如何实现这一目标?

解决方法

把它作为日期投射:
SELECT    
     cast(VoteDate as date) as VoteDate,SUM(CASE WHEN Vote = 1 THEN 1 ELSE 0 END) AS Total
FROM      Votes
WHERE VoteDate between dateadd(day,-7,GETDATE()) and GETDATE()
GROUP BY  cast(VoteDate as date)

您的VoteDate列是日期时间,但您只需要日期部分.最简单的方法是将其转换为日期类型.您可以阅读有关SQL Server日期类型here的更多信息.

如果您的投票列是1或0,您可以将总和(投票)作为总计而不是执行案例陈述.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读