可能重复:
Create a date with T-SQL
我有一个数据表,将每年,每月和每天的值存储为整数:
year | month | day
2009 | 1 | 1
2008 | 12 | 2
2007 | 5 | 5
我需要将其转换为datetime值,因为我需要在操作之间的日期时间使用它。我怎么能这样做?
答案 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