Mysql DATETIME与TIMESTAMP的区别

TIMESTAMP的取值范围小,并且TIMESTAMP类型的日期时间在存储时会将当前时区的日期时间值转换为时间标准时间值,检索时再转换回当前时区的日期时间值。

而DATETIME则只能反映出插入时当地的时区,其他时区的人查看数据必然会有误差的。

DATETIME:日期时间,8字节。格式为YYYY-MM-DD HH:MM:SS,取值范围1000-01-01 00:00:00 至 9999-12-31 23:59:59

TIMESTAMP:时间戳,4字节。格式为YYYY-MM-DD HH:MM:SS,取值范围1970-01-01 00:00:01 UTC 至 2038-01-19 03:14:07 UTC

创建一张表,包含2种数据类型。如下:

bash 复制代码
mysql> create table tb_datetime(
    -> num1 datetime,
    -> num2 timestamp);
Query OK, 0 rows affected (1.25 sec)

mysql> desc tb_datetime;
+-------+-----------+------+-----+---------+-------+
| Field | Type      | Null | Key | Default | Extra |
+-------+-----------+------+-----+---------+-------+
| num1  | datetime  | YES  |     | NULL    |       |
| num2  | timestamp | YES  |     | NULL    |       |
+-------+-----------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> insert into tb_datetime values ('2023-2-28 21:21:12','2023-2-28 21:21:12');
Query OK, 1 row affected (0.14 sec)

mysql> select * from tb_datetime;
+---------------------+---------------------+
| num1                | num2                |
+---------------------+---------------------+
| 2023-02-28 21:21:12 | 2023-02-28 21:21:12 |
+---------------------+---------------------+
1 row in set (0.00 sec)

这个时候看到的数据是一样的。

接着,修改时区信息:

bash 复制代码
mysql> set time_zone = "+9:00";
Query OK, 0 rows affected (0.00 sec)

mysql> select * from tb_datetime;
+---------------------+---------------------+
| num1                | num2                |
+---------------------+---------------------+
| 2023-02-28 21:21:12 | 2023-02-28 22:21:12 |
+---------------------+---------------------+
1 row in set (0.00 sec)

可以看到,num2即TIMESTAMP类型的数据,跟着时区变化了。

相关推荐
小智RE0-走在路上14 分钟前
Python学习笔记(13) --Mysql,Python关联数据库
数据库·python·学习
x66ccff23 分钟前
Claude Code 安装方法
android·java·数据库
嘟嘟w25 分钟前
MySQL 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?
数据库·mysql
四谎真好看25 分钟前
MySQL 学习笔记(进阶篇3)
笔记·学习·mysql·学习笔记
星光一影27 分钟前
智慧停车与充电一体化管理平台:打造城市出行新生态
mysql·vue·能源·springboot·uniapp
JH灰色31 分钟前
【大模型】-LlamaIndex框架(与LangChain区别)
数据库·langchain
没有bug.的程序员38 分钟前
服务治理体系:从零到一的全景落地指南
java·开发语言·数据库·微服务·架构
ha_lydms39 分钟前
4、Spark 函数_m/n/o/p/q/r
大数据·数据库·python·sql·spark·数据处理·dataworks
草莓熊Lotso40 分钟前
2025年12月远程协作平台全景评测:智能连接时代的效率革命
运维·服务器·数据库
Coder_Boy_42 分钟前
开源向量数据库比较(Chroma、Milvus、Faiss、Weaviate)
数据库·人工智能·spring boot·开源·milvus