mysql那些事(2)时间类型数据如何存储
2017-12-29 10:45
381 查看
几乎每次数据库建模的时候,都会遇到时间类型数据存储的问题。
mysql存储时间通常选择这四种类型:datetime、timestamp、int和bigint四种方式,到底使用什么类型,需要看具体的业务。
我们分别对这四种类型进行讨论。
1、datetime
这个类型可以存储8字节,表示从1000到9999年之间的数据。这个类型可以为空值,也可以自定义值,默认的初始值是“0000-00-00 00:00:00”。
这种类型存储的存储的优点是数据可读性强,不需要函数做转换。
2、timestamp
这个类型的存储长度是4个字节,表示的范围是:'1970-01-01 00:00:01'-'2038-01-19 03:14:07’,可以为空值,也可以自定义值。需要注意的是这个字段创建时如果加上 “on update current_timestamp”时,该字段插入值时,会自动变为当前的系统时间。
3、int
这个类型的存储长度是4字节,一般用来存储linux时间戳的形式,存储精度为秒。表示最大是 date('Y-m-d H:i:s', 4294967295) 最大到 2106-02-07 14:28:15,可以为空值,但是业务逻辑设计时尽量使用非空值。它的优点是数值型存储,节省空间。但是可读性差。另外,如果业务上经常需要按照时间进行排列或者查询的话,尽量使用int类型。
4、bigint
这个类型的存储长度是8个字节,从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。适合业务精确的时间存储,它的存储精度为毫秒。优缺点请参考int。
另外,mysql中的时间存储还有以下类型:
YEAR :字节数为1,取值范围为“1901——2155”。
DATE,字节数为4,取值范围为“1000-01-01——9999-12-31”。
TIME,字节数为3,取值范围为“-838:59:59——838:59:59”。
在实际的数据库建模过程中,用的比较少一些。
综上,我们认为时间的存储需要根据具体的业务场景来定。一般来说,int类型使用较多,一方面查询效率高,另一方面可以显示时间的方式比较灵活,一般语言都提供转化的函数,如大家熟知的php中的date()函数。
mysql存储时间通常选择这四种类型:datetime、timestamp、int和bigint四种方式,到底使用什么类型,需要看具体的业务。
我们分别对这四种类型进行讨论。
1、datetime
这个类型可以存储8字节,表示从1000到9999年之间的数据。这个类型可以为空值,也可以自定义值,默认的初始值是“0000-00-00 00:00:00”。
这种类型存储的存储的优点是数据可读性强,不需要函数做转换。
2、timestamp
这个类型的存储长度是4个字节,表示的范围是:'1970-01-01 00:00:01'-'2038-01-19 03:14:07’,可以为空值,也可以自定义值。需要注意的是这个字段创建时如果加上 “on update current_timestamp”时,该字段插入值时,会自动变为当前的系统时间。
3、int
这个类型的存储长度是4字节,一般用来存储linux时间戳的形式,存储精度为秒。表示最大是 date('Y-m-d H:i:s', 4294967295) 最大到 2106-02-07 14:28:15,可以为空值,但是业务逻辑设计时尽量使用非空值。它的优点是数值型存储,节省空间。但是可读性差。另外,如果业务上经常需要按照时间进行排列或者查询的话,尽量使用int类型。
4、bigint
这个类型的存储长度是8个字节,从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。适合业务精确的时间存储,它的存储精度为毫秒。优缺点请参考int。
另外,mysql中的时间存储还有以下类型:
YEAR :字节数为1,取值范围为“1901——2155”。
DATE,字节数为4,取值范围为“1000-01-01——9999-12-31”。
TIME,字节数为3,取值范围为“-838:59:59——838:59:59”。
在实际的数据库建模过程中,用的比较少一些。
综上,我们认为时间的存储需要根据具体的业务场景来定。一般来说,int类型使用较多,一方面查询效率高,另一方面可以显示时间的方式比较灵活,一般语言都提供转化的函数,如大家熟知的php中的date()函数。
相关文章推荐
- MySQL中日期类型数据的使用:如何让字段保存记录的创建时间和最后修改时间
- [小白技巧]如何在Linux上检查MySQL数据表的存储引擎类型
- MySQL时间类型数据存储datetime、timestamp、int
- MySQL基础教程4 —— 数据类型之存储需求及如何选择正确的类型
- mysql中时间类型如何存储
- mysql如何选择合适的数据类型存储不同的数据
- mysql数据表中有日期为date类型,时间为time类型。此处的date存储的是年月日,time存储的是时分秒
- MySQL入门经典-----2、如何存储和获取数据(MySQL存储引擎、数据类型和运算符)
- mysql当中时间类型是如何存储的
- mysql数据Unix时间戳与C# DateTime时间类型互换
- 在Mysql中用 LONGBLOB 类型存储二进制数据
- 如何查看MySQL支持的数据类型?
- Mysql的timestamp类型,自动记录数据的更新时间
- Mysql的timestamp类型,自动记录数据的更新时间
- MySQL datetime数据类型设置当前时间为默认值
- MySQL日期数据类型、时间类型使用总结
- 如何设定MySQL中timestamp类型字段自动设定为当前时间
- 在Mysql中用 LONGBLOB 类型存储二进制数据
- Qt QHash 和QMap 区别时间: 2010-11-17 / 浏览次数: 75 views / 1个评论 发表评论QMap提供了一个从类项为key的键到类项为T的直的映射,通常所存储的数据类型是一个键对应一个直,并且按照Key的次序存储数据,
- MySQL日期数据类型、时间类型使用总结