开发者社区> 问答> 正文

mysql数据库的timestamp为什么从1970到2038的某一时间?某一时间是指什么时间?过了这个时间之后怎么办?

如题。
1 mysql数据库的timestamp为什么从1970到2038的某一时间?
2某一时间是指什么时间?
3过了这个时间之后怎么办?

展开
收起
a123456678 2016-06-24 14:33:19 4143 0
1 条回答
写回答
取消 提交回答
  • 首先你要理解什么是时间戳。时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至某一时间点的总秒数。

    例如北京时间2015-12-31 17:00:00的时间戳是1451552400,就是指从北京时间1970-01-01 08:00:00到2015-12-31 17:00:00已经过去了1451552400秒。

    网上有在线的时间戳转换工具:http://tool.chinaz.com/Tools/unixtime.aspx

    下面一一问答你的问题:

    1、MySQL数据库的timestamp为什么从1970到2038的某一时间?
    MySQL的timestamp类型是4个字节,最大值是2的31次方减1,也就是2147483647,转换成北京时间就是2038-01-19 11:14:07。可以使用上面的在线的时间戳转换工具得出。

    2、某一时间是指什么时间?
    如上,北京时间是2038-01-19 11:14:07。

    3、过了这个时间之后怎么办?
    1) 使用datetime;
    2) 等过了再说。

    最后补充一个彩蛋:北京时间2038-01-19 11:14:07,如果某些系统还在使用MySQL的Timestamp,或者系统使用的编程语言用4字节补码整型(例如Java的int)来表示时间戳的,这些系统都会跪掉,说不定会搞出点什么大新闻(例如飞机航班系统挂掉、银行某系统跪掉),好吧,我乱猜的,等着那一天吧。

    2019-07-17 19:46:56
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像