SQLserver 实现分组统计查询(按月、小时分组)
网络编程 2021-07-05 13:42www.168986.cn编程入门
创建数据表IP地址,访问时间和访问次数。如果每访问一次就插入一条记录,那么AessCount可以不要,查询时使用count就可以了,这样当访问量很大的时候会对数据库造成很大压力。
设置AessCount字段可以根据需求在特定的时间范围内如果是相同IP访问就在AessCount上累加。
代码如下:
Create table Counter
(
CounterID int identity(1,1) not null,
IP varchar(20),
AessDateTime datetime,
AessCount int
)
该表在这儿只是演示使用,所以只提供了最基本的字段
现在往表中插入几条记录
insert into Counter
select '127.0.0.1',getdate(),1 union all
select '127.0.0.2',getdate(),1 union all
select '127.0.0.3',getdate(),1
1 根据年来查询,以月为时间单位
通常情况下一个简单的分组就能搞定
代码如下:
select
convert(varchar(7),AessDateTime,120) as Date,
sum(AessCount) as [Count]
from
Counter
group by
convert(varchar(7),AessDateTime,120)
像这样分组后没有记录的月份不会显示,如下
这不是我们想要的,所以得换一种思路来实现,如下
代码如下:
declare @Year int
set @Year=2009
select
m as [Date],
sum(
case when datepart(month,AessDateTime)=m
then AessCount else 0 end
) as [Count]
from
Counter c,
(
select 1 m
union all select 2
union all select 3
union all select 4
union all select 5
union all select 6
union all select 7
union all select 8
union all select 9
union all select 10
union all select 11
union all select 12
) aa
where
@Year=year(AessDateTime)
group by
m
查询结果如下
2 根据天来查询,以小时为单位。这个和上面的类似,代码如下
代码如下:
declare @DateTime datetime
set @DateTime=getdate()
select
right(100+a,2)+ ':00 -> '+right(100+b,2)+ ':00 ' as DateSpan,
sum(
case when datepart(hour,AessDateTime)> =a
and datepart(hour,AessDateTime) <b
then AessCount else 0 end
) as [Count]
from Counter c ,
(select 0 a,1 b
union all select 1,2
union all select 2,3
union all select 3,4
union all select 4,5
union all select 5,6
union all select 6,7
union all select 7,8
union all select 8,9
union all select 9,10
union all select 10,11
union all select 11,12
union all select 12,13
union all select 13,14
union all select 14,15
union all select 15,16
union all select 16,17
union all select 17,18
union all select 18,19
union all select 19,20
union all select 20,21
union all select 21,22
union all select 22,23
union all select 23,24
) aa
where datediff(day,@DateTime,AessDateTime)=0
group by right(100+a,2)+ ':00 -> '+right(100+b,2)+ ':00 '
查询结果如下图
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程