前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mysql - date、datetime、timestamp 的区别

Mysql - date、datetime、timestamp 的区别

作者头像
小菠萝测试笔记
发布2021-11-16 14:15:17
5.8K1
发布2021-11-16 14:15:17
举报

date、datetime 的区别

  • 顾名思义,date 日期,datetime 日期时间,所以 date 是 datetime 的日期部分
  • MySQL 以 格式检索和显示 datetime 值

YYYY-MM-DD hh:mm:ss

datetime 支持的日期时间范围
代码语言:javascript
复制
1000-01-01 00:00:00 ~ 9999-12-31 23:59:59

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

  • 它们都是以 格式检索和显示日期时间

YYYY-MM-DD hh:mm:ss

  • 第一个区别是 timestamp 支持的日期时间范围不如 datetime 大
timestamp 支持的日期时间范围

是 UTC 时间

代码语言:javascript
复制
'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 值的范围变成
代码语言:javascript
复制
1000-01-01 00:00:00.000000 ~ 9999-12-31 23:59:59.999999
timestamp 值的范围变成
代码语言:javascript
复制
1970-01-01 00:00:01.000000 ~ 2038-01-19 03: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' 的任何值
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-11-12 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • date、datetime 的区别
    • datetime 支持的日期时间范围
    • datetime 和 timestamp 的区别一:时间范围
      • timestamp 支持的日期时间范围
        • 什么是 UTC
        • datetime 或 timestamp 值可以包括尾部小数秒部分
          • datetime 值的范围变成
            • timestamp 值的范围变成
            • datetime 和 timestamp 区别二:时区
              • 和 datetime 的区别
              • datetime 和 timestamp 区别三:字节数
                • 重点
                  • timestamp 节省一个字节是有代价的
                  相关产品与服务
                  云数据库 SQL Server
                  腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
                  领券
                  问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档