Mysql - date、datetime、timestamp 的区别

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: Mysql - date、datetime、timestamp 的区别

date、datetime 的区别


  • 顾名思义,date 日期,datetime 日期时间,所以 date 是 datetime 的日期部分
  • MySQL 以 YYYY-MM-DD hh:mm:ss 格式检索和显示 datetime 值

 

datetime 支持的日期时间范围

1000-01-0100:00:00 ~ 9999-12-3123:59:59

 

datetime 和 timestamp 的区别一:时间范围


  • 它们都是以 YYYY-MM-DD hh:mm:ss 格式检索和显示日期时间
  • 第一个区别是 timestamp 支持的日期时间范围不如 datetime 大

 

timestamp 支持的日期时间范围

是 UTC 时间

'1970-01-01 00:00:01' UTC  -'2038-01-19 03:14:07' UTC

 

什么是 UTC

协调世界时间,世界统一时间,世界标准时间,国际协调时间

 

datetime 或 timestamp 值可以包括尾部小数秒部分


  • 精度最高可达微秒(6 位小数位)
  • 插入到 datetime 或 timestamp 列的值中的任何小数部分都会被保留而不是被丢弃
  • 保留小数部分后,格式变成 YYYY-MM-DD hh:mm:ss[.fraction]

 

datetime 值的范围变成

1000-01-0100:00:00.000000~9999-12-3123:59:59.999999

 

timestamp 值的范围变成

1970-01-0100:00:01.000000~2038-01-1903:14:07.999999

 

datetime 和 timestamp 区别二:时区


  • 因为 timestamp 存储的是 UTC 时间,所以会时区的概念,这也是区别于 datetime 地方之一
  • MySQL 对于 timestamp 字段值,会将客户端插入的时间从当前时区转换为 UTC 再进行存储;查询时,会从 UTC 转换回客户端当前时区再进行返回
  • 默认情况下,每个连接的当前时区是服务器的时间
  • 可以在每个连接的基础上设置时区,只要时区设置保持不变,该 timestamp 字段读写的值就会保持一致

 

和 datetime 的区别

datetime 没有时区概念,客户端传什么时间就存什么时间,省去了转换时区的步骤

 

datetime 和 timestamp 区别三:字节数


datetime 和 timestamp 存储的都是二进制而不是字符串

  • timestamp:4 个字节
  • datetime:5 个字节(有些教程会写 8 个,但官方文档目前 mysql8  中 datetime 是 5 个字节进行存储)

 

重点

  • 它们在保存小数秒时,都将使用额外的空间(1-3 个字节)
  • 如果存储 150w 条记录,1 个字节的差异可以忽略不计
  • 150 万条记录 * 每条记录 1 个额外字节/(1048576 字节/MB)= 1.43 MB

 

timestamp 节省一个字节是有代价的

  • 最开始也说了,timestamp 只能存储 '1970-01-01 00:00:01.000000' 到 '2038-01-19 03:14:07.999999' 的值
  • 但 datetime 可以存储 '1000-01-01 00:00:00.000000' 到 '9999-12-31 23:59:59.999999' 的任何值

 

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
15天前
|
存储 关系型数据库 MySQL
ES的全文索引和MySQL的全文索引有什么区别?如何选择?
【8月更文挑战第26天】ES的全文索引和MySQL的全文索引有什么区别?如何选择?
67 5
|
25天前
|
前端开发 关系型数据库 MySQL
com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的区别
这篇文章讨论了`com.mysql.jdbc.Driver`和`com.mysql.cj.jdbc.Driver`两个MySQL驱动类的区别,指出`com.mysql.jdbc.Driver`适用于MySQL 5的`mysql-connector-java`版本,而`com.mysql.cj.jdbc.Driver`适用于MySQL 6及以上版本的`mysql-connector-java`。文章还提到了在实际使用中如何根据MySQL版本选择合适的驱动类。
com.mysql.jdbc.Driver 和 com.mysql.cj.jdbc.Driver 的区别
|
30天前
|
存储 SQL 关系型数据库
OceanBase与MySQL有何区别?
【8月更文挑战第12天】OceanBase与MySQL有何区别?
47 3
|
13天前
|
SQL 关系型数据库 MySQL
Mysql中from多表跟join表的区别
Mysql中from多表跟join表的区别
37 0
|
15天前
|
关系型数据库 MySQL
Mysql中count(1)、count(*)以及count(列)的区别
Mysql中count(1)、count(*)以及count(列)的区别
26 0
|
17天前
|
关系型数据库 MySQL 数据库
MySQL MVCC和间隙锁有什么区别?
【8月更文挑战第24天】MySQL MVCC和间隙锁有什么区别?
31 0
|
2月前
|
SQL 关系型数据库 MySQL
MySQL删除表数据、清空表命令(truncate、drop、delete 区别)
MySQL删除表数据、清空表命令(truncate、drop、delete区别) 使用原则总结如下: 当你不需要该表时(删除数据和结构),用drop; 当你仍要保留该表、仅删除所有数据表内容时,用truncate; 当你要删除部分记录、且希望能回滚的话,用delete;
|
19天前
|
SQL 关系型数据库 MySQL
【揭秘】MySQL binlog日志与GTID:如何让数据库备份恢复变得轻松简单?
【8月更文挑战第22天】MySQL的binlog日志记录数据变更,用于恢复、复制和点恢复;GTID为每笔事务分配唯一ID,简化复制和恢复流程。开启binlog和GTID后,可通过`mysqldump`进行逻辑备份,包含binlog位置信息,或用`xtrabackup`做物理备份。恢复时,使用`mysql`命令执行备份文件,或通过`innobackupex`恢复物理备份。GTID模式下的主从复制配置更简便。
83 2
|
15天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
18天前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决

热门文章

最新文章

下一篇
DDNS