当前位置: 首页 > 图文教程 > 数据库 > MSSQL > 跟我学SQL:(九)datetime和interval数据类型

MSSQL
SQL Server 中死锁产生的原因及解决办法
教你在SQL Server 2000数据库中使用分区
数据仓库基本报表制作过程中的SQL写法
自动定时重启sql server回收内存
轻松解决SQL Server 2005中的常见问题
用一个案例讲解SQL Server数据库恢复
安装SQL Server 2005时出现计数器错误
讲解SQL Server 2005数据库的同义词Bug
利用SQL语句对不同数据库进行高效果分页
三种数据库利用SQL语句进行高效果分页
数据库连接字符串的常见问题和解决方法
教你快速掌握一些方便易用的SQL语句
深入分析SQL Server的数据转换服务
系统默认的MySQL用户名消失的解决方法
SQL 2008邮件故障排除:发送测试电子邮件
SQL Server 2005日志文件损坏的处理方法
在SQL Server 2005数据库中进行错误捕捉
SQL Server查询速度慢原因及优化方法
加密SQL Anywhere 提升政府行业数据安全
Windows Server 2008之数据安全保护

MSSQL 中的 跟我学SQL:(九)datetime和interval数据类型


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 120 ::
收藏到网摘: n/a

  datetime和interval是两种与时间有关的数据类型。它们的作用体现在以下几个方面:创建或者更改记录库中的某条记录、当某个时间发生时运行记录、或者计算某个datetime变量建立后所经历过的时间。本文将介绍SQL92标准对上述两种数据类型的描述。 



  
SQL数据类型

如果你想进一步了解SQL数据类型,请阅读SQL基础:字符串型数据类型,这篇文章的范围覆盖了SQL中的通用数据类型并说明了各种字符串数据类型的用法,SQL基础:数字数据类型详细介绍了数字数据类型。



Datetime
用于表示时间或者日期的数据类型都属于datetime类型。每一种datetime数据类型都有他自己的用于获取值的长度和它所保存信息的手段,如天、月、分钟、秒、秒的小数等等。

实际上,datetime的实现形式随着定义它的标准不同而拥有不同的长度和格式;然而,各个公司定义的类型都内在地符合下述规则。举例来说,时标(timestamp)的某个实现可能没有分隔符,随着细节的规范不同,长度和格式也发生变化,在某些场合以空格做为间隔符。Datetime数据类型包括:DATA、TIME和TIMESTAMP。让我们仔细研究这些分类,首先我们看看DATA。

DATA
用法:DATA

DATA类型允许没有参数,如精度。 
DATA的字段包括年、月和日。 
DATA的长度为十个字符: YYYY-MM-DD。(Y表示年、M表示月、D表示日。) 
它只允许与其它DATA类型字段相比较。 
允许的数字必须符合公历的规范。 
TIME
用法:TIME(精度)

该类型包含了小时、分和秒,格式为hh:mm:ss(h表示小时、m表示分、s表示秒) 
精度可选择,(……) 
时间以世界标准时间(Universal Coordinated Time,UTC)为准,即00:00:00表示.格林威治的午夜,服务器的时区隐含的。 
如果不需要秒的小数部分,那么TIME的长度为八个字符。否则就是八位长度在加上精度:hh:mm:ss.p。 
它只能与其它TIME类型数据进行比较。 
如果没有指定精度,精度默认为0。 

TIME WITH TIME ZONE

  
用法:TIME (精度) WITH TIME ZONE 

这个值要符合TIME数据类型 
TIMEZONE部分表示相对UTC的时差:00:00:00+hh:mm。它的范围为-12:59到13:00。 
精度表示秒的小数部分。 
带有TIMEZONE的TIME长度为14个字符加上精度,在加上一个分隔符。 
只可以与带有TIMEZONE的TIME类型数据进行比较 
TIMESTAMP

用法:TIMESTAMP(精度)

该类型包含有年、月、日、时、分、秒,格式为:YYYY-MM-DD hh:mm:ss.。 
可以包括秒的小数部分,这由定义的精度决定。 
它的日期部分符合公历标准,时间部分为UTC格式。默认为当地时区。 
时标的长度为19个字符,加上精度,在加上精度分隔符。 
许多系统偏离上述定义的长度,如UNIX风格时标格式为:,YYYY-MM-DD hh:mm:ss.p。 
如果没有定义精度,默认值为6,但是许多数据库公司默认为0,所以请参考你的开发文档。 
时标只可以与其它TIMESTAMP类型的值相比较。 
TIMESTAMP WITH TIME ZONE

用法:TIMESTAMP(精度)WITH TIME ZONE 

时标部分符合上述TIMESTAWP的规则。 
精度代表秒的小数部分。 
时区部分的要求和TIME WITH TIME ZONE一样,即时区符合UTC规范,范围在-12:59到 +13:00之间。 
总长度为25个字符,加上精度,加上一个精度分隔符:YYYY-MM-DD hh:mm:ss.p。 
它只能与其它TIMESTAMP WITH TIME ZONE类型的数据进行比较。 
Interval

Interval用于表示时间尺度。例如,你可以用操作符(将在下面进行解释)去计算两个日期间天数并加以保存。

各个公司在处理interval上有很大的不同——有些公司提供不同的度量单位,如年或者分钟,而有些公司在根本就不支持interval。SQL92标准的interval类型只提供一种子类型:INTERVAL。


INTERVAL 

用法: INTERVAL (限定语)

有两种类型的interval:一种为“年份-月份”,即保存年份和月份(YYYY-MM);一种为“天-时间”(DD HH:MM:SS),用来保存天数、小时、分钟和秒。 
限定语——在某些数据库中interval前导精度(lead precision)——根据其值来指示interval采用“年份-月份”还是“天-时间”方式。 
interval可正可负。 
当与其它interval类型变量相比较时,结果保持最大精度,如有必要则补零。 
INTERVAL全部由整数组成,除了含有小数的秒之外。 
 “年份-月份”类型的interval变量只能与其它的“年份-月份”的interval变量进行比较。“天-时间”类型也与此类似。 
操作符