我的代码每10分钟生成一些数据集 - 日志或每30分钟 - 日志,但日期时间格式为'1900-01-01 14:20:00'
。我需要'2009-05-13 14:20:00'
,所以我想改变它。
见下面的表1和表2.
declare @date1 nvarchar(100) , @date2 nvarchar(100) , @countgap int,@count int
set @date1='2009-05-12'
set @date2 = '2009-05-13'
set @countgap = 10 --per ten minutes
CREATE TABLE #Temp (VisitingCount int, [Time] int, [Date] datetime )
DECLARE @DateNow DATETIME,@i int,@Time int, @Date datetime
set @DateNow='00:00'
set @i=1;
insert into #Temp(VisitingCount,[Time],[Date]) values(0,0,@DateNow )
while(@i<(24*60)/@countgap)
begin
set @DateNow = DATEADD(minute, @countgap, @DateNow)
set @Time = (datepart(hour,@DateNow)*60+datepart(minute,@DateNow))/@countgap
set @Date = CONVERT(VARCHAR(5),@DateNow, 108)
insert into #Temp(VisitingCount,[Time],[Date]) values(0,@Time,@Date )
set @i=@i+1
end
select
Sum(VisitingCount) as VisitingCount, [Time],
Cast( RIGHT('00'+Cast([Time]*@countgap/60 as varchar(2) ),2) +':'+RIGHT('00'+Cast( [Time]*@countgap%60 as varchar(2) ),2) as Smalldatetime)as VisitingGap
from (
select 0 as VisitingCount, [Time] from #Temp
Union All
select count(page) as VisitingCount,
(datepart(hour,Date)*60+datepart(minute,Date))/@countgap as [Time]
from scr_SecuristLog
where Date between @date1 and @date2
GROUP BY (datepart(hour,Date)*60+datepart(minute,Date))/@countgap
) X
group by [Time]
order by 2 asc
表1
VCount Time VisitingGap 6 86 1900-01-01 14:20:00 17 87 1900-01-01 14:30:00 9 88 1900-01-01 14:40:00 20 89 1900-01-01 14:50:00 19 90 1900-01-01 15:00:00 0 91 1900-01-01 15:10:00 7 92 1900-01-01 15:20:00 4 93 1900-01-01 15:30:00 8 94 1900-01-01 15:40:00 9 95 1900-01-01 15:50:00 0 96 1900-01-01 16:00:00 20 97 1900-01-01 16:10:00 24 98 1900-01-01 16:20:00
表2
VCount Time VisitingGap ... 6 86 2009-05-13 14:20:00 17 87 2009-05-13 14:30:00 9 88 2009-05-13 14:40:00 20 89 2009-05-13 14:50:00 19 90 2009-05-13 15:00:00 ...
我想我需要改变这个:
Cast( RIGHT('00'+Cast([Time]*@countgap/60 as varchar(2) ),2) +':'+RIGHT('00'+Cast( [Time]*@countgap%60 as varchar(2) ),2) as Smalldatetime)as VisitingGap
答案 0 :(得分:1)
为什么不将日期变量声明为datetime?
declare @date1 datetime
declare @date2 datetime
set dateformat ymd
set @date1 = '2009-05-12'
set @date1 = '2009-05-13'
...
这样,您就不必进行从nvarchar到datetime的任何转换。
或者,如果数据来自外部,使用set dateformat
,您可以先将其转换。
答案 1 :(得分:1)
您正在使用SmallDateTime值。 其最小值为01/01/1900。
我看到您将DateNow设置为'00:00'这会将其设置为日期最小值加上时间'00:00'。
您需要将其设置为当前日期或至少是您的计时器首先基于的任何开始日期。