如何将nvarchar更改为datetime格式?

时间:2009-05-13 09:19:48

标签: sql sql-server sql-server-2005

我的代码每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

2 个答案:

答案 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'。

您需要将其设置为当前日期或至少是您的计时器首先基于的任何开始日期。