首页 > 数据库 >MySQL 中 DATETIME 和 TIMESTAMP 时间类型详解

MySQL 中 DATETIME 和 TIMESTAMP 时间类型详解

时间:2024-10-21 09:11:01浏览次数:7  
标签:00 TIMESTAMP 存储 DATETIME 时间 MySQL

MySQL的日期类型简介

在 MySQL 中有两种存储时间的数据类型 DATETIME 和 TIMESTAMP,它们在数据库实际应用中,各有各的优势和劣势。

一. DATETIME 和 TIMESTAMP 的相同点

  1. 两个数据类型存储时间的格式一致。均为 YYYY-MM-DD HH:MM:SS
  2. 两个数据类型都包含「日期」和「时间」部分。
  3. 两个数据类型都可以存储微秒的小数秒(秒后6位小数秒)

二. DATETIME 和 TIMESTAMP 的区别

1.表示范围

  • DATETIME1000-01-01 00:00:00.000000 到 9999-12-31 23:59:59.999999
  • TIMESTAMP1970-01-01 00:00:01.000000 UTC 到 2038-01-09 03:14:07.999999 UTC

2.空间占用

  • TIMESTAMP:占 4 个字节(小数秒+3 个字节)
  • DATETIME:在 MySQL 5.6.4 之前,占 8 个字节 ,之后版本,占 5 个字节。(小数秒+3 个字节)

3.存入时间是否会自动转换?

  • TIMESTAMP:TIMESTAMP 的值是从「当前时间」转换成 UTC 时间,或者反过来转换。
  • DATETIME:不会做任何转换,也不会检测时区,你给什么数据,它存什么数据。

4.使用 now() 存储当前时间时,保存的实际值,是否与当前计算机时间一致?

  • TIMESTAMP:可能不一致。存储值会被转换成 UTC 时间值再存入数据库。
  • DATETIME:与当前时间是一致的。

5.如果存入的是 NULL 时,两个类型如何存储?

  • TIMESTAMP:会自动存储当前时间( now() )。
  • DATETIME:不会自动存储当前时间,会直接存入 NULL 值。

三. 使用场景辨析

在什么场景中,使用 DATETIME 或 TIMESTAMP 更合适?

TIMESTAMP 使用场景:计算飞机飞行时间

一架飞机,从中国北京起飞,降落在美国纽约,计算它从北京飞往纽约的飞行时间。飞机在北京时间 2021-10-10 11:05:00 从北京起飞,在纽约时间 2021-10-10 09:50:00 降落(JL8006)。

这个场景中,如果使用 TIMESTAMP 来存时间,起飞和降落时间的值,都会被转换成 UTC 时间,所以它们直接相减即可获得结果。但如果使用 DATATIME 格式存时间,还需要进行转换,才可以完成,容易出错。

DATATIME 使用场景:记录信息修改时间

如果只是记录文件修改时间,最后更新时间这种不涉及加减转换的情况,用 DATATIME 来存更直接,更方便,可读性高,不绕弯子,不容易出错。

标签:00,TIMESTAMP,存储,DATETIME,时间,MySQL
From: https://www.cnblogs.com/shujuyr/p/18488321

相关文章

  • C10-08-宽字节注入-mysql注入之getshell-sqlmap
    一宽字节注入利用宽字节注入实现“库名-表名”的注入过程。靶场环境:容器镜像:area39/pikachu宽字节概念1、如果一个字符的大小是一个字节的,称为窄字节;2、如果一个字符的大小是两个及以上字节的,称为宽字节;像GB2312、GBK、GB18030、BIG5、Shift_JIS等编码都是常见的宽字节......
  • [数据库][mysql]MySQL基础
    1,数据库相关概念以前我们做系统,数据持久化的存储采用的是文件存储。存储到文件中可以达到系统关闭数据不会丢失的效果,当然文件存储也有它的弊端。假设在文件中存储以下的数据:姓名 年龄 性别 住址张三 23 男 北京西三旗李四 24 女 北京西二旗王五 25 男 西安软件新城现......
  • [数据库][mysql]mysql高级
    1,约束上面表中可以看到表中数据存在一些问题:id列一般是用标示数据的唯一性的,而上述表中的id为1的有三条数据,并且 马花疼 没有id进行标示柳白 这条数据的age列的数据是3000,而人也不可能活到3000岁马运 这条数据的math数学成绩是-5,而数学学得再不好也不可能出现负分......
  • 【重学 MySQL】七十三、灵活操控视图数据,轻松掌握视图删除技巧
    【重学MySQL】七十三、灵活操控视图数据,轻松掌握视图删除技巧更新视图数据:灵活操控,即时反映删除视图:优雅清理,保持数据库整洁深度解析:为何更新和删除视图如此重要?结语在MySQL的数据管理中,视图(View)作为一种虚拟表,为我们提供了极大的便利,它不仅能够简化复......
  • MySQL5.7 InnoDB在线DDL操作
    MYSQL官方文档:https://dev.mysql.com/doc/refman/5.7/en/innodb-online-ddl.html目录在线DDL原理在线DDL支持情况IndexOperations(索引操作)PrimaryKeyOperations(主键操作)ColumnOperations(列操作)TableOperations(表操作)pt-osc方式在线DDL和pt-osc对比参考在线DDL原理MySQL5.6......
  • 数据库—MySQL的主从备份
    MySQL主从备份  服务器有可能突然挂机,如果是docker部署MySQL则也有可能容器突然坏了,这样对于数据库的使用自然会造成不少的影响,因此,需要对数据库采用一个高可用架构。  一个比较常见的场景就是主从备份,通常来说都是一主一从或者一主多从。主机进行工作,从机备份数据,如......
  • MYSQL的基本语法格式以及简单使用
    文章目录前言一、SQL能做什么二、MYSQL的基本使用1.SQL的SELECT语句2.SQL的INSERTINTO语句3.SQL的UPDATE语句4.SQL的DELETE语句5.SQL的WHERE子句6.SQL的AND和OR运算符7.SQL中的ORDERBY子句8.SQL的COUNT(*)函数9.使用AS关键字为列设置别名前言SQL是结构化查询语......
  • mysql对结果集进行遍历(mysql双重for循环如何写)
    原文链接:mysql对结果集进行遍历(mysql双重for循环如何写)–每天进步一点点0.背景有这么一个需求:对以下的类型结果集进行更新。更新的原则是type为c的currentValue的值=(type为b的currentValue)/((type为b的currentValue)+(type为a的currentValue))*100。上面这个需求......
  • count(*)、count(1)哪个更快?面试必问:通宵整理的十道经典MySQL必问面试题
    一、你是如何理解Count(*)和Count(1)的?这两个并没有区别,不要觉得count()会查出全部字段,而count(1)不会。所以count()会更慢,你觉得MySQL作者会这么做吗?可以很明确地告诉你们count()和count(1)是一样的,而正确有区别的是count(字段)。如果你count()的是具体的字段,那......
  • 【MySQL】子查询,合并查询
    目录1.子查询1.1.单行子查询1.2.多行子查询1.3.多列子查询 1.4.在from子句里面使用子查询 2.合并查询 1.子查询         子查询,也称为嵌套查询或子选择,是SELECT嵌入在另一个SQL查询的 WHERE 或 HAVING子句中的查询。子查询返回的数据由外部语句使用......