SQL Server:将((int)year,(int)month,(int)day)转换为Datetime

时间:2009-12-17 19:03:26

标签: sql-server datetime

  

可能重复:
  Create a date with T-SQL

我有一个数据表,将每年,每月和每天的值存储为整数:

year | month | day
2009 |   1   |  1 
2008 |  12   |  2
2007 |   5   |  5

我需要将其转换为datetime值,因为我需要在操作之间的日期时间使用它。我怎么能这样做?

4 个答案:

答案 0 :(得分:68)

为了独立于语言和区域设置,您应该使用ISO 8601 YYYYMMDD格式 - 这将适用于任何语言和区域设置生效的SQL Server系统:

SELECT
   CAST(
      CAST(year AS VARCHAR(4)) +
      RIGHT('0' + CAST(month AS VARCHAR(2)), 2) +
      RIGHT('0' + CAST(day AS VARCHAR(2)), 2) 
   AS DATETIME)

答案 1 :(得分:37)

纯日期时间解决方案,不依赖于语言或DATEFORMAT,没有字符串

SELECT
    DATEADD(year, [year]-1900, DATEADD(month, [month]-1, DATEADD(day, [day]-1, 0)))
FROM
    dbo.Table

答案 2 :(得分:8)

您可以将您的值转换为“十进制”日期时间,然后将其转换为实际的日期时间列:

select cast(rtrim(year *10000+ month *100+ day) as datetime) as Date from DateTable

有关详细信息,请参阅here

答案 3 :(得分:2)

SELECT CAST(CAST(year AS varchar) + '/' + CAST(month AS varchar) + '/' + CAST(day as varchar) AS datetime) AS MyDateTime
FROM table