[MySQL] 有坑,timestamp和datetime的区别

CREATE TABLE `tag_res`  (
  `creater` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
  `created_at` timestamp(0) NULL DEFAULT NULL,
  `expired_at` datetime(0) NULL DEFAULT NULL
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic;

1、  timestamp占用4个字节;

  datetime占用8个字节;


2、  timestamp范围1970-01-01 00:00:01.000000 到 2038-01-19 11:14:07.999999;

  datetime是1000-01-01 00:00:00.000000 到 9999-12-31 23:59:59.999999;

  注意:timestamp存储时在超过存储范围的时候会报错

  


3、  timestamp默认支持not null default CURRENT_TIMESTAMP自动更新当前时间;

  datetime 在5.6版本后才支持,需要手动指定not null default CURRENT_TIMESTAMP;

  
4、  timestamp转成utc(世界标准时间)存储,查询再自动转回来;

  datetime原样存储

timestamp为啥只到2038?

先看看mysql如何存储的:

对于timestamp,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。底层表示是时间戳。什么是时间戳?

时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至某一时间点的总秒数。

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

MySQL的timestamp类型是4个字节,最大值是2的31次方减1,也就是2147483647,转换成北京时间就是2038-01-19 11:14:07

要想大于这个时间,就用datetime   

datetime是常量,而timestamp受time_zone设置的影响,只有当将来可能 - 跨时区同步集群时,这才有意义。timestamp一般用于跟踪记录被更新的时间或创建时间.

基于项目考虑,以上因素不会影响到业务,所以果断换成datetime。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值