设为首页 收藏本站
查看: 1421|回复: 0

[经验分享] SQL Server 2008中四种DATETIME数据类型

[复制链接]

尚未签到

发表于 2015-7-4 13:27:12 | 显示全部楼层 |阅读模式
   SQL Server 2008中DATETIME功能的最大转变就是引入了四种DATETIME数据类型,分别为DATE、TIME、DATETIMEOFFSET和DATETIME2;此外还增加了新的DATETIME函数功能。  下面首先来讨论一下四种新数据类型的功能和用法。
  DATE数据类型
  在SQL Server 2005中,没有专门只用来存储日期(不包括时间)的特定数据类型,只能使用DATETIME或SMALLDATETIME数据类型来完成此操作。但是,当你输入日期之后,会显示还有一个时间的组分需要输入,其初始显示为12:00 AM。如果只想在输出结果中显示日期那一部分,就必须修改输出格式。大部分情况下,可以使用getdate()函数来存储当前日期。要在SQL Server 2005中的SMALLDATETIME或DATETIME列中保存getdate()的函数值,同时也会保存了当前的时间,而这可能会引发很多问题。举例而言,如果你使用以下的语句,想根据给定的日期来搜索记录:
  SELECT * FROM tblDate Where [Date] = '2007-12-01'
  由于Date列里含有时间组分,这个命令将无法正常执行, 因此,你必须执行以下的查询操作:
  SELECT * FROM tblDate Where datediff(d,[Date],‘2007-12-01’) =0
  尽管上面的查询操作可以行得通,不过Date列中符合要求的索引很可能不会被使用。不过你还是可以使用上面的查询操作调出少量的记录。虽然可以利用工作区,但很明显有必要增加一种去掉时间值的DATE数据类型来减少潜在的错误。来看看以下的语法:
  
  DECLARE @dt as DATE
  SET @dt = getdate()
  PRINT @dt

  以上脚本的输出结果只有日期,不包括时间部分。DATE数据类型的取值范围从0001-01-01到9999-12-31。
  TIME数据类型
  就像日期数据类型一样,如果你只想存储时间数据而不需要日期部分就可以利用TIME数据类型。下面就是利用TIME数据类型进行查询的例子:
  
  DECLARE @dt as TIME
  SET @dt = getdate()
  PRINT @dt

  以上脚本输出结果只包含时间部分,其取值范围从00:00:00.0000000到23:59:59.9999999。
  DATETIME2数据类型
  新的DATETIME2数据类型也是一种数据时间混合的数据类型,不过其时间部分秒数的小数部分可以保留不同位数的值,比原来的DATETIME数据类型取值范围要广。用户可以根据自己的需要通过设置不同的参数来,设定小数位数,最高可以设到小数点后七位(参数为7),也可以不要小数部分(参数为0),以此类推。以下是利用DATETIME2的查询语句:
  
  DECLARE @dt7 datetime2(7)
  SET @dt7 = Getdate()
  PRINT @dt7

  该语句的输出结果中时间的秒数部分精确到小数点后第七位。
 DATETIMEOFFSET数据类型
  如果把日期和时间数据保存在一列里,是不会提示该日期和时间属于哪一个时区的。时区的提示非常重要,特别是当你处理数据包含了多个不同时区的国家时。新的DATETIMEOFFSET数据类型可以定义一个日期和时间组合,其中时间以24小时制显示,并带有时区提示。下面的语句说明了DATETIMEOFFSET数据类型的用法:
  
  DECLARE @dt DATETIMEOFFSET(0)
  SET @dt = '2007-12-04 21:20:30 -1:00'
  DECLARE @dt1 DATETIMEOFFSET(0)
  SET @dt1 = '2007-12-04 21:20:30 +5:00'
  SELECT DATEDIFF(hh,@dt,@Dt1)

  DateTime函数
  目前我们可以在SQL Server 2005和SQL Server 2000中使用GETDATE函数来查询当前的日期和时间。此外,在SQL Server 2005中,还有另外几个类似的日期时间函数,分别为:CURRENT_TIMESTAMP、DATEADD、DATEDIFF、DATENAME、DATEPART、GETUTCDATE、DAY、 MONTH和YEAR。而在SQL Server 2008中,除了上述这些函数外,又新增了五个函数,分别为SYSDATETIME、SYSDATETIMEOFFSET、SYSUTCDATETIME、SWITCHOFFSET和TODATETIMEOFFSET。其中SYSDATETIME函数返回目前系统的时间戳,不带时区提示,能够精确到毫秒级。SYSDATETIMEOFFSET函数和SYSDATETIME函数功能类似,不过包含了时区值。SYSUTCDATETIME返回以世界标准时间(又称协调世界时,也就是格林威治时间)表示的日期和时间,也精确到毫秒级,是根据当前SQL Server运行所在地服务器所设置的本地时间和时区得来的。SYSDATETIME和SYSUTCDATETIME两个函数返回的都是DATETIME2数据类型,而SYSDATETIMEOFFSET函数返回DATETIMEOFFSET数据类型。
  SWITCHOFFSET函数
  SWITCHOFFSET函数返回DATETIMEOFFSET数据类型的值,不再根据存储的时区偏移值取值,而是根据设定的新时区偏倚值来取值。看看下面这个语句:
  SELECT SYSDATETIMEOFFSET(), SWITCHOFFSET (SYSDATETIMEOFFSET(), '-14:00')
  该脚本返回两个列,第一列是根据世界标准时间得到的当前日期和时间值,第二列则是根据给定的时区偏移值返回的日期时间值。
  TODATETIMEOFFSET函数
  TODATETIMEOFFSET函数可以把本地日期或时间值以及特定的时区偏移值转变为一个datetimeoffset值。运行以下脚本,你会看到返回的结果中除了当前日期和时间外,还增加了时区值。
  SELECT TODATETIMEOFFSET (GETDATE(),'+11:00')
  转换函数
  CONVERT函数可以从DATETIME数据类型的组成中抽取时间值或者日期值。运行以下脚本,返回结果的第一列为当前日期,第二列为当前时间。
  SELECT CONVERT(date, GETDATE()),CONVERT(time, GETDATE())
  使用新DATETIME数据类型进行转换的注意事项
  如果你要增加DATE和TIME列,不能够像SMALLDATETIME数据类型一样加载,否则会返回以下的错误信息:Operand data type date is invalid for add operator。
  你可以尝试把这两列设置为浮点型数据,一起存入,并把结果转换成SMALLDATETIME或DATETIME列。(记住,当SMALLDATETIME数据存储成浮点型时,日期值为整数部分而时间值为小数部分)不过,这也会返回一个错误信息:Explicit conversion from data type date to float is not allowed。
  正确的做法是把两列都转换为SMALLDATETIME数据,并一起存入。例如使用以下脚本,你就可以得到输出结果:
  
  Declare @dt as DATE
  Set @dt = getdate()
  Declare @dtt as TIME
  Set @dtt = getdate()
  Select cast(@dt as smalldatetime) + cast(@dtt as smalldatetime)

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-83097-1-1.html 上篇帖子: SQL Server 重建索引 Rebuild Index 下篇帖子: SQL Server 2005 中的商务智能和数据仓库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表