mysql的DATETIME和TIMESTAMP数据类型有什么区别

MySQL :: MySQL 8.2 Reference Manual :: 11.2.2 The DATE, DATETIME, and TIMESTAMP Types

  • 都可以表示日期和时间:DATETIMETIMESTAMP 数据类型都可以保存包含日期和时间的部分,格式为'YYYY-MM-DD hh:mm:ss [.fraction ]',其中[.fraction]代表可选的小数部分,即可以到微妙,例如2038-01-19 03:14:07.499999
  • 表示的时间范围不同:DATETIME 可以表示的时间范围是从'1000-01-01 00:00:00.000000''9999-12-31 23:59:59.499999',而TIMESTAMP可以表示的时间范围是从'1970-01-01 00:00:01.000000'到'2038-01-19 03:14:07.499999'。
  • 存储和显式方式有区别:MySQL在保存TIMESTAMP的时候,是将当前的时区转换为UTC时间存储,显示的时候又从UTC转换到当前时区,而DATETIME 没有这种转换过程。如果先保存了TIMESTAMP的值,然后改变时区,再取回TIMESTAMP的值,会跟存储的不同,这因为存储转换的时区和取回的转换时区不同。
  • 存储需求不同:

MySQL :: MySQL 8.2 Reference Manual :: 11.7 Data Type Storage Requirements

| Data Type | Storage Required Before MySQL 5.6.4 | Storage Required as of MySQL 5.6.4 |
| YEAR | 1 byte | 1 byte |
| DATE | 3 bytes | 3 bytes |
| TIME | 3 bytes | 3 bytes + fractional seconds storage |
| DATETIME | 8 bytes | 5 bytes + fractional seconds storage |

TIMESTAMP 4 bytes 4 bytes + fractional seconds storage
相关推荐
S1998_1997111609•X10 小时前
论当今社会主义与人文关怀人格思想下的恶意仿生注入污染蜜罐描述进行函数值非法侵入爬虫的咼忄乂癿〇仺⺋.
数据库·网络协议·百度·ssh·开闭原则
倔强的石头_11 小时前
kingbase备份与恢复实战(六)—— 备份自动化与保留策略:Windows任务计划+日志追溯
数据库
轻刀快马12 小时前
别被 ORM 框架宠坏了:从一场“订单消失”悬案,看懂 MySQL 为什么要强推 InnoDB
数据库·mysql
后端漫漫13 小时前
Redis 客户端工具体系
数据库·redis·缓存
PaperData14 小时前
1988-2025年《中国人口和就业统计年鉴》全年份excel+PDF
数据库·人工智能·数据分析·经管
星河耀银海15 小时前
C语言与数据库交互:SQLite实战与数据持久化
c语言·数据库·sqlite·交互
过期动态15 小时前
MySQL中的约束
android·java·数据库·spring boot·mysql
程序员陆通15 小时前
月烧 400 刀到不到 20 刀:我是怎么把 OpenClaw 的 Token 账单砍掉 95% 的
java·前端·数据库
Shan120515 小时前
站在计算机领域视角看:SQL注入攻击
网络·数据库·sql
轻刀快马16 小时前
别干背八股文了:从一场“双十一秒杀”惨案,看懂 InnoDB 事务、锁与索引的底层齿轮
数据库·sql