SQL中datetime和interval数据类型的作用是什么

50次阅读
没有评论

共计 2458 个字符,预计需要花费 7 分钟才能阅读完成。

这篇文章将为大家详细讲解有关 SQL 中 datetime 和 interval 数据类型的作用是什么,文章内容质量较高,因此丸趣 TV 小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

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 变量进行比较。“天-时间”类型也与此类似。 
操作符

操作结果类型

当处理日期时间时,时区保持不变——尽管有些数据库为了比较而将其中的一个时区转换为另一个。存在一些操作关键字,如 OVERLAPS 和 EXTRACT,它们用于操作和比较 datetime 类型数据。然而,不同的数据库在这些操作关键字用法和支持方式上有着很大的不同。

OVERLAPS 用于计算时间交叠的跨度,其操作对象可以是两个 datetime 也可以是一个 datetime 和一个 interval。EXTRACT 用于提取 datetime 或者 interval 类型数据的某个部分,如在 DATA 类型数据中提取月份。

数据类型
由于已建立的标准是为了各公司在现有基础上实现实际上的数据类型的,因此在具体限制、参数和数据类型等方面,你还是需要经常参考你的数据库文档。

关于 SQL 中 datetime 和 interval 数据类型的作用是什么就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-03发表,共计2458字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)