MySQL 时间类型的选择


Posted in MySQL onJune 05, 2021

MySQL 提供了 DATETIME 和 TIMESTAMP 两种非常相似的类型处理日期和时间,大部分情况下两种都是 OK 的,但是有些情况二者会互有优劣。

DATETIME

DATETIME 的时间跨度更大,可以从1001年到9999年,精度是秒。并且存储的格式是将日期和时间打包使用 YYYYMMDDhhmmss格式的整数存储,这个时间与时区无关,需要占用8个字节的存储空间。默认,MySQL 显示 的DATETIME是有序的,明确的格式,例如2021-06-02 18:35:23。这是 ANSI 的标准日期时间格式。

TIMESTAMP

TIMESTAMP即时间戳,存储的是自格林威治时间(GMT)1970年1月1日零点以来的秒数。和 Unix 系统的时间戳一样。TIMESTAMP 仅需要4个字节存储,因此能够表示的时间跨度更小,从1970年到2038年。MySQL 提供了 FROM_UNIXTIME 和 UNIX_TIMESTAMP 函数来完成时间戳和日期之间的转换。

在 MySQL 4.1版本后,TIMESTAMP 显示的格式和 DATETIME 类似,但是,TIMESTAMP 的显示依赖于时区。MySQL 的服务端、操作系统以及客户端连接都有时区的设置。因此,如果时间是从多个时区存储的话,那 TIMESTAMP 和 DATETIME 的差别就会很大。TIMESTAMP 会保留使用时的时区信息,而 DATETIME 仅仅是使用文本表示时间。

TIMESTAMP 还有额外的特性。默认地,MySQL会在没有指定值的情况下使用当前时间插入到 TIMESTAMP列,而更新的时候如果没有指定值会使用当前时间更新该字段,以下面的测试表为例:

CREATE TABLE t_time_test (
    id INT PRIMARY KEY,
    t_stamp TIMESTAMP,
    t_datetime DATETIME
);

可以看到MySQL 给的默认值就是当前时间戳 CURRENT_TIMESTAMP,并且有个 ON UPDATE CURRENT_TIMESTAMP表示会随之更新:

MySQL 时间类型的选择

INSERT INTO t_time_test(id, t_datetime) VALUES
	(1, NULL), 
	(2, '2021-06-02 18:48:04'), 
	(3, NULL);

可以看到 t_stamp 列自动填充了当前时间。

MySQL 时间类型的选择

这个特性使得我们可以物协程序维护数据更新时间字段,而交由 MySQL 完成。

如何选择

从特性上看,可能会优先选择使用 TIMESTAMP 来存储时间,相比 DATETIME 来说更高效。也有些人使用整数存储 Unix 时间戳,实际上这种方式并不能获益,而且整数还需要额外进行处理,因此并不推荐这么做。但是一些情况需要注意不要使用 TIMESTAMP 存储时间:

  • 生日:生日肯定会有早于1970年的,会超出 TIMESTAMP 的范围
  • 有效期截止时间:TIMESTAMP 的最大时间是2038年,如果用来存类似身份证的有效期截止时间,营业执照的截止时间等就不合适。
  • 业务生存时间:互联网时代讲究快,发展(死得)快。如果要成为长久存在的企业,那么你的业务时间很可能在2038年还在继续运营,毕竟现在都2021年了。如果你觉得公司业务挺不到2038年,那没关系。当然,如果幸运地挺到2038年,请务必写下一条待办事项:到2038年1月1日前修改数据表时间戳字段类型。

如何存储毫秒级时间

通常这个时候需要使用 BIGINT 来将时间转换为整型存储,或者是使用浮点数,用分数部分表示秒精度一下的时间,这两种方式都可行。当然,这个时候需要应用支持做格式转换。

结语

从安全稳妥的角度考虑,建议还是优先选择 DATETIME 类型,虽然相比 TIMESTAMP 会牺牲一点性能,但是 TIMESTAMP 的时间范围是硬伤,不要埋下一个隐患,等到真的2038年,你的公司可能是上市公司的时候,程序员可能会遭遇洪水般的 bug 冲击而不明所以,结果公司的股价迎来闪崩!然后找出来这个程序员,发现是曾经公司的大神,目前的股东,已经实现财务自由的你!你说尴尬不尴尬?

以上就是MySQL 时间类型的选择的详细内容,更多关于MySQL 时间类型的资料请关注三水点靠木其它相关文章!

MySQL 相关文章推荐
数据库的高级查询六:表连接查询:外连接(左外连接,右外连接,UNION关键字,连接中ON与WHERE的不同)
Apr 05 MySQL
.Net Core导入千万级数据至Mysql的步骤
May 24 MySQL
Mysql 如何实现多张无关联表查询数据并分页
Jun 05 MySQL
为什么MySQL分页用limit会越来越慢
Jul 25 MySQL
SQL实现LeetCode(176.第二高薪水)
Aug 04 MySQL
深入讲解数据库中Decimal类型的使用以及实现方法
Feb 15 MySQL
MySQL实现配置主从复制项目实践
Mar 31 MySQL
MySQL 数据表操作
May 04 MySQL
mysql 排序失效
May 20 MySQL
Mysql中mvcc各场景理解应用
Aug 05 MySQL
MySQL中dd::columns表结构转table过程及应用详解
Sep 23 MySQL
SQLyog的下载、安装、破解、配置教程(MySQL可视化工具安装)
Sep 23 MySQL
MySQL索引失效的典型案例
Jun 05 #MySQL
MySQL库表名大小写的选择
Jun 05 #MySQL
mysql 带多个条件的查询方式
Mysql 如何实现多张无关联表查询数据并分页
Jun 05 #MySQL
Mysql中存储引擎的区别及比较
浅谈mysql返回Boolean类型的几种情况
Jun 04 #MySQL
Mysql 设置boolean类型的操作
Jun 04 #MySQL
You might like
php GeoIP的使用教程
2011/03/09 PHP
2个Codeigniter文件批量上传控制器写法例子
2014/07/25 PHP
php集成环境xampp中apache无法启动问题解决方案
2014/11/18 PHP
PHP实现断点续传乱序合并文件的方法
2018/09/06 PHP
laravel 实现上传图片到本地和前台访问示例
2019/10/21 PHP
关于hashchangebroker和statehashable的补充文档
2011/08/08 Javascript
JavaScript设计模式之工厂模式和构造器模式
2015/02/11 Javascript
JavaScript框架是什么?怎样才能叫做框架?
2015/07/01 Javascript
jQuery原型属性和原型方法详解
2015/07/07 Javascript
jQuery实现的文字hover颜色渐变效果实例
2016/02/20 Javascript
JS密码生成与强度检测完整实例(附demo源码下载)
2016/04/06 Javascript
详解微信小程序开发之城市选择器 城市切换
2017/01/17 Javascript
iOS + node.js使用Socket.IO框架进行实时通信示例
2017/04/14 Javascript
Mac系统下Webstorm快捷键整理大全
2017/05/28 Javascript
基于Vue组件化的日期联动选择器功能的实现代码
2018/11/30 Javascript
11个教程中不常被提及的JavaScript小技巧(推荐)
2019/04/17 Javascript
vue父子组件的通信方法(实例详解)
2019/11/10 Javascript
vue axios请求成功却进入catch的原因分析
2020/09/08 Javascript
[02:22:36]《加油!DOTA》总决赛
2014/09/19 DOTA
[01:55]《走出家门看比赛》——DOTA2 2015国际邀请赛同城线下观战
2015/07/18 DOTA
Python的Twisted框架中使用Deferred对象来管理回调函数
2016/05/25 Python
Python写的一个定时重跑获取数据库数据
2016/12/28 Python
python中Matplotlib实现绘制3D图的示例代码
2017/09/04 Python
python中使用正则表达式的后向搜索肯定模式(推荐)
2017/11/11 Python
Pytorch: 自定义网络层实例
2020/01/07 Python
pytorch下使用LSTM神经网络写诗实例
2020/01/14 Python
python模式 工厂模式原理及实例详解
2020/02/11 Python
解决Django no such table: django_session的问题
2020/04/07 Python
520使用Python实现“我爱你”表白
2020/05/20 Python
Expedia法国:全球最大在线旅游公司
2018/09/30 全球购物
德国大型和小型家用电器网上商店:Energeto
2019/05/15 全球购物
婚礼新郎父母答谢词
2014/01/16 职场文书
汽车维修专业自荐书
2014/05/26 职场文书
pycharm debug 断点调试心得分享
2021/04/16 Python
微信小程序结合ThinkPHP5授权登陆后获取手机号
2021/11/23 PHP
Node.js实现爬取网站图片的示例代码
2022/04/04 NodeJs