MySQL 中 datetime 和 timestamp 的区别与选择

 更新时间:2021年09月26日 10:33:22   作者:程淇铭  
MySQL 中常用的两种时间储存类型分别是datetime和 timestamp。如何在它们之间选择是建表时必要的考虑。下面就谈谈他们的区别和怎么选择,需要的朋友可以参考一下

MySQL 中常用的两种时间储存类型分别是datetimetimestamp。如何在它们之间选择是建表时必要的考虑。下面就谈谈他们的区别和怎么选择。

1 区别

1.1 占用空间

类型 占据字节 表示形式
datetime 8 字节 yyyy-mm-dd hh:mm:ss
timestamp 4 字节 yyyy-mm-dd hh:mm:ss

1.2 表示范围

类型 表示范围
datetime '1000-01-01 00:00:00.000000' to '9999-12-31 23:59:59.999999'
timestamp '1970-01-01 00:00:01.000000' to '2038-01-19 03:14:07.999999'

timestamp翻译为汉语即"时间戳",它是当前时间到 Unix元年(1970 年 1 月 1 日 0 时 0 分 0 秒)的秒数。对于某些时间的计算,如果是以 datetime 的形式会比较困难,假如我是 1994-1-20 06:06:06 出生,现在的时间是 2016-10-1 20:04:50 ,那么要计算我活了多少秒钟用 datetime 还需要函数进行转换,但是 timestamp 直接相减就行。

1.3 时区

timestamp 只占 4 个字节,而且是以utc的格式储存, 它会自动检索当前时区并进行转换。

datetime以 8 个字节储存,不会进行时区的检索.

也就是说,对于timestamp来说,如果储存时的时区和检索时的时区不一样,那么拿出来的数据也不一样。对于datetime来说,存什么拿到的就是什么。

还有一个区别就是如果存进去的是NULL,timestamp会自动储存当前时间,而 datetime会储存 NULL。

2 测试

我们新建一个表

插入数据

查看数据,可以看到存进去的是NULLtimestamp会自动储存当前时间,而 datetime会储存NULL

把时区修改为东 9 区,再查看数据,会会发现 timestamp datetime 多一小时

如果插入的是无效的呢?假如插入的是时间戳

结果是0000-00-00 00:00:00,根据官方的解释是插入的是无效的话会转为 0000-00-00 00:00:00,而时间戳并不是MySQL有效的时间格式。

那么什么形式的可以插入呢,下面列举三种

//下面都是 MySQL 允许的形式,MySQL 会自动处理
2016-10-01 20:48:59
2016#10#01 20/48/59
20161001204859

3 选择

如果在时间上要超过Linux时间的,或者服务器时区不一样的就建议选择 datetime

如果是想要使用自动插入时间或者自动更新时间功能的,可以使用timestamp

如果只是想表示年、日期、时间的还可以使用 yeardatetime,它们分别占据 1、3、3 字节,而datetime就是它们的集合。

到此这篇关于MySQL datetime timestamp 的区别与选择的文章就介绍到这了,更多相关MySQL 中 datetime timestamp 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • MySQL与Redis如何保证双写一致性详解

    MySQL与Redis如何保证双写一致性详解

    双写一致性是指在系统中同时使用缓存(如Redis)和数据库(如MySQL)时,如何确保两者的数据保持一致,这篇文章主要介绍了MySQL与Redis如何保证双写一致性的相关资料,需要的朋友可以参考下
    2025-10-10
  • MySQL创建数据库和创建数据表的操作过程

    MySQL创建数据库和创建数据表的操作过程

    MySQL 是最常用的数据库,在数据库操作中,基本都是增删改查操作,简称CRUD,这篇文章主要介绍了MySQL创建数据库和创建数据表的操作过程,需要的朋友可以参考下
    2022-11-11
  • mysql的语句查询顺序、耗时分析以及查询调优技巧分享

    mysql的语句查询顺序、耗时分析以及查询调优技巧分享

    文章详细介绍了MySQL中SQL查询语句的执行顺序、耗时分析及查询调优方法,包括使用EXPLAIN、SHOW PROFILE和慢查询日志等工具进行耗时分析,以及使用索引、避免全表扫描、优化查询语句、分区表和调整服务器配置等技巧进行性能优化
    2025-02-02
  • explain执行计划需要关注的几个关键字段详细解释

    explain执行计划需要关注的几个关键字段详细解释

    这篇文章主要介绍了explain执行计划需要关注的几个关键字段的相关资料,EXPLAIN是MySQL性能优化的关键工具,它提供了查询执行计划的详细信息,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-02-02
  • mysql使用source 命令乱码问题解决方法

    mysql使用source 命令乱码问题解决方法

    从windows上导出一个sql执行文件,再倒入到unbutn中,结果出现乱码,折腾7-8分钟,解决方式在导出mysql sql执行文件的时候,指定一下编码格式
    2013-04-04
  • 深入MYSQL字符数字转换的详解

    深入MYSQL字符数字转换的详解

    本篇文章是对MYSQL中的字符数字转换进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • SQL字段拼接成新字段几种常见的方法

    SQL字段拼接成新字段几种常见的方法

    这篇文章主要给大家介绍了关于SQL字段拼接成新字段几种常见的方法,如我们在选择商品的时候不止需要知道商品的名字,还需要商品代码型号等,这个时候需要把这些字段拼接为一个字段进行操作或者输出,需要的朋友可以参考下
    2023-08-08
  • Express项目中操作MySQL的步骤

    Express项目中操作MySQL的步骤

    本文详细介绍了如何在Express项目中操作MySQL数据库,包括安装配置、连接数据库、执行SQL语句以及处理查询结果等关键步骤,感兴趣的朋友跟随小编一起看看吧
    2025-02-02
  • MySQL 用 limit 为什么会影响性能

    MySQL 用 limit 为什么会影响性能

    对于小的偏移量,直接使用limit来查询没有什么问题,但随着数据量的增大,越往后分页,limit语句的偏移量就会越大,速度也会明显变慢,接下来文章就向大家介绍其的原由,感兴趣的小伙伴可参考下面文章具体内容
    2021-09-09
  • mysql中如何使用正则表达式查询

    mysql中如何使用正则表达式查询

    这篇文章主要介绍了mysql中如何使用正则表达式查询,需要的朋友可以参考下
    2014-06-06

最新评论