bal*_*int 41 sql-server datetime
可能重复:
使用T-SQL创建日期
我有一个数据表,将每年,每月和每天的值存储为整数:
year | month | day
2009 | 1 | 1
2008 | 12 | 2
2007 | 5 | 5
Run Code Online (Sandbox Code Playgroud)
我需要将它转换为datetime值,因为我需要在操作之间的日期时间使用它.我怎么能这样做?
mar*_*c_s 69
为了独立于语言和区域设置,您应该使用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)
Run Code Online (Sandbox Code Playgroud)
gbn*_*gbn 37
纯日期时间解决方案,不依赖于语言或DATEFORMAT,没有字符串
SELECT
DATEADD(year, [year]-1900, DATEADD(month, [month]-1, DATEADD(day, [day]-1, 0)))
FROM
dbo.Table
Run Code Online (Sandbox Code Playgroud)
您可以将值转换为"十进制"日期时间,然后将其转换为实际的日期时间列:
select cast(rtrim(year *10000+ month *100+ day) as datetime) as Date from DateTable
Run Code Online (Sandbox Code Playgroud)
有关详细信息,请参阅此处.