您的位置:首页 > 数据库

SQL Server 2008对日期时间类型的改进

2010-08-30 13:08 411 查看
在新版的SQL Server 2008中一口气增加了4种新的日期时间数据类型,包括:

Date:一个纯的日期数据类型。

Time:一个纯的时间数据类型。

DateTime2:新的日期时间类型,将精度提到到了100纳秒。

DateTimeOffset:新的日期时间类型,在DateTime2的基础上增加了时区部分。

下面是在SQL Server 2008中日期时间数据类型的一个简单汇总表:

数据类型格式取值范围精度存储尺寸
Dateyyyy-mm-dd 0001-1-1至9999-12-31

1天3字节
Timehh:mm:ss:nnnnnn 0:0:0.000000至23:59:59.999999100纳秒3-5字节
smalldatetimeyyyy-mm-dd hh:mm:ss1900-1-1至2079-6-61分钟4字节
datetimeyyyy-mm-dd hh:mm:ss:nnn1753-1-1至9999-12-310.00333秒8字节
datetime2yyyy-mm-dd hh:mm:ss:nnnnnn0001-1-1至9999-12-31100纳秒6-8字节
datetimeoffsetyyyy-mm-dd hh:mm:ss:nnnnnn +|- hh:mm0001-1-1至9999-12-31(全球标准时间)100纳秒8-10字节
为了使用这些数据类型,SQL Server 2008同时还引入了一系列的T-SQL函数。
三个用于获得高精度系统时间的函数(因为是这三个函数都是取的操作系统时间,所以精度仅能达到10毫秒):

SYSDATETIME:返回运行SQL Server实例的服务器的本地时间,数据类型是datetime2(7),不包含时区信息。

SYSDATETIMEOFFSET:返回运行SQL Server实例的服务器的本地时间及时区信息,数据类型是datetimeoffset(7)。

SYSUTCDATETIME:返回运行SQL Server实例的服务器的标准世界时间,数据类型是datetime2(7)。

用于时区转换的函数:

SWITCHOFFSET(datetimeoffset,time_zone):根据输入的世界时间以及时区信息返回某个特定时区的数据,例如SWITCHOFFSET('2008-1-1 0:0:0 + 8:00', '-07:00')返回值将是'2007-12-31 9:00 -07:00',这样我们就晓得我们元旦的时候老美的时间只是早上9:00。(有个有趣的情况是SWITCHOFFSET函数time_zone参数小时的前导0时不能省略的,就我们刚才用的那个例子如果time_zone参数写成'7:00'就会报错,必须写成'07:00',不过datetimeoffset数据里那个时区部分小时的前导0时可以省略的,也就是说'2008-1-1 0:0:0 + 8:00'和'2008-1-1 0:0:0 + 08:00'都是可以接受的,对于时区中分钟部分也是如此。不过建议大家养成良好的编码习惯,所有前导0都不要省略。)

TODATETIMEOFFSET(datetime,offset):根据输入的日期时间参数值和时区参数值返回一个世界时间值。例如TODATETIMEOFFSET('2008-1-1 0:0:0', '+08:00')返回值是'2008-1-1 0:0:0 + 08:00'。

顺便列举一下SQL Server 2005中已经提供的日期时间函数,不过就不做介绍了:

用于获取系统时间的函数:CURRENT_TIMESTAMP,GETDATE,GETUTCDATE

返回日期时间的指定部分:DATENAME,DATEPART,DAY,MONTH,YEAR

计算日期时间差异的函数:DATEDIFF, DATEADD (必须注意的是datetime、smalldatetime数据类型支持+和-运算符,但是对于date、time、datetime2、datetimeoffset则不支持。)

对日期时间进行计算的函数:DATEADD

设置日期时间显示格式的函数:@@DATEFIRST,SET DATEFIRST,SET DATEFORMAT,@@LANGUAGE,SET LANGUAGE,sp_helplanguage

用于确认日期时间数据格式的函数:ISDATE
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: