datetime和interval是两种与时间有关的数据类型 它们的作用体现在以下几个方面 创建或者更改记录库中的某条记录 当某个时间发生时运行记录 或者计算某个datetime变量建立后所经历过的时间 本文将介绍SQL 标准对上述两种数据类型的描述 SQL数据类型如果你想进一步了解SQL数据类型 请阅读SQL基础 字符串型数据类型 这篇文章的范围覆盖了SQL中的通用数据类型并说明了各种字符串数据类型的用法 SQL基础 数字数据类型详细介绍了数字数据类型 Datetime用于表示时间或者日期的数据类型都属于datetime类型 每一种datetime数据类型都有他自己的用于获取值的长度和它所保存信息的手段 如天 月 分钟 秒 秒的小数等等 实际上 datetime的实现形式随着定义它的标准不同而拥有不同的长度和格式 然而 各个公司定义的类型都内在地符合下述规则 举例来说 时标(timestamp)的某个实现可能没有分隔符 随着细节的规范不同 长度和格式也发生变化 在某些场合以空格做为间隔符 Datetime数据类型包括 DATA TIME和TIMESTAMP 让我们仔细研究这些分类 首先我们看看DATA DATA用法 DATADATA类型允许没有参数 如精度 DATA的字段包括年 月和日 DATA的长度为十个字符 YYYY MM DD (Y表示年 M表示月 D表示日 ) 它只允许与其它DATA类型字段相比较 允许的数字必须符合公历的规范 TIME用法 TIME(精度)该类型包含了小时 分和秒 格式为hh:mm:ss(h表示小时 m表示分 s表示秒) 精度可选择 (……) 时间以世界标准时间(Universal Coordinated Time UTC)为准 即 : : 表示 格林威治的午夜 服务器的时区隐含的 如果不需要秒的小数部分 那么TIME的长度为八个字符 否则就是八位长度在加上精度 hh:mm:ss p 它只能与其它TIME类型数据进行比较 如果没有指定精度 精度默认为 TIME WITH TIME ZONE 用法 TIME (精度) WITH TIME ZONE 这个值要符合TIME数据类型 TIMEZONE部分表示相对UTC的时差 : : +hh:mm 它的范围为 : 到 : 精度表示秒的小数部分 带有TIMEZONE的TIME长度为 个字符加上精度 在加上一个分隔符 只可以与带有TIMEZONE的TIME类型数据进行比较 TIMESTAMP用法 TIMESTAMP(精度)该类型包含有年 月 日 时 分 秒 格式为 YYYY MM DD hh:mm:ss 可以包括秒的小数部分 这由定义的精度决定 它的日期部分符合公历标准 时间部分为UTC格式 默认为当地时区 时标的长度为 个字符 加上精度 在加上精度分隔符 许多系统偏离上述定义的长度 如UNIX风格时标格式为 YYYY MM DD hh:mm:ss p 如果没有定义精度 默认值为 但是许多数据库公司默认为 所以请参考你的开发文档 时标只可以与其它TIMESTAMP类型的值相比较 TIMESTAMP WITH TIME ZONE用法 TIMESTAMP(精度)WITH TIME ZONE 时标部分符合上述TIMESTAWP的规则 精度代表秒的小数部分 时区部分的要求和TIME WITH TIME ZONE一样 即时区符合UTC规范 范围在 : 到 + : 之间 总长度为 个字符 加上精度 加上一个精度分隔符 YYYY MM DD hh:mm:ss p 它只能与其它TIMESTAMP WITH TIME ZONE类型的数据进行比较 IntervalInterval用于表示时间尺度 例如 你可以用 *** 作符(将在下面进行解释)去计算两个日期间天数并加以保存 各个公司在处理interval上有很大的不同——有些公司提供不同的度量单位 如年或者分钟 而有些公司在根本就不支持interval SQL 标准的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类型数据中提取月份 数据类型由于已建立的标准是为了各公司在现有基础上实现实际上的数据类型的 因此在具体限制 参数和数据类型等方面 你还是需要经常参考你的数据库文档 lishixinzhi/Article/program/SQLServer/201311/22163
主要考虑,要符合应用实际,便于使用,在存储空间上尽量节省
可以参考如下
1,char 和 varchar
若长度固定,且字符数在15个以内,选择 char,否则,选择varchar;
2,decimal 和 float
decimal 用于存放精确的数据,float 用于存放非精确的数据,如果要存放精确的数据,选择 decimal;
float 的存储空间开销一般小于 decimal,若需要存放非精确的数据,选择 float;
3,时间类型
使用 int 来存储:优点:字段长度比 datetime 小;缺点:使用不方便;通常还是使用 datetime 类型;
注意存储的时间粒度:只是存放年份,用数据类型 YEAR 比较好,占用的空间小
祝好运,望采纳。
数据库类型还是数据类型?
数据库类型直接innodb
数据类型则遵从以下规则:
整数:int
金额:decimal
日期:date
日期时间:datetime
可变长度字符:varchar;即不确定有多长
固定长度字符:char;即知道字符长度,比如md5()32位
文章详情等:longtext
以上就是关于跟我学SQL:datetime和interval数据类型全部的内容,包括:跟我学SQL:datetime和interval数据类型、数据库应用中,在为字段选择数据类型时,需要从哪几个方面考虑、mysql数据库类型有哪些如何选择合适的数据类型等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)