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
相关推荐
@游子8 小时前
SQL注入语法和介绍(一)
数据库·oracle
蒋士峰DBA修行之路11 小时前
实验十三 WDR诊断报告
数据库
杂亿稿11 小时前
数据库的约束
数据库
u***324311 小时前
使用python进行PostgreSQL 数据库连接
数据库·python·postgresql
Codingwiz_Joy11 小时前
Day44 盲注、报错注入 & 实战复现
数据库·安全性测试
7***998713 小时前
GaussDB数据库中SQL诊断解析之配置SQL限流
数据库·sql·gaussdb
Wang's Blog14 小时前
MongoDB小课堂: 文档操作核心技术指南:主键机制、CRUD操作与最佳实践
数据库·mongodb
i***t91914 小时前
Linux下MySQL的简单使用
linux·mysql·adb
g***267915 小时前
最新SQL Server 2022保姆级安装教程【附安装包】
数据库·性能优化
风123456789~16 小时前
【OceanBase专栏】OB背景知识
数据库·笔记·oceanbase