首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysql记录时间用什么类型

MySQL记录时间可以使用以下几种数据类型:

1. DATETIME

  • 基础概念:DATETIME类型用于存储日期和时间,格式为'YYYY-MM-DD HH:MM:SS',范围从'1000-01-01 00:00:00'到'9999-12-31 23:59:59'。
  • 优势:支持日期和时间的精确到秒的存储,适用于大多数需要记录具体时间的场景。
  • 应用场景:适用于需要记录创建时间、更新时间等具体时间的表。

2. TIMESTAMP

  • 基础概念:TIMESTAMP类型也用于存储日期和时间,格式为'YYYY-MM-DD HH:MM:SS',范围从'1970-01-01 00:00:01' UTC到'2038-01-19 03:14:07' UTC。
  • 优势:自动初始化和更新当前时间戳,节省存储空间。
  • 应用场景:适用于需要自动记录创建时间和更新时间的表。

3. DATE

  • 基础概念:DATE类型仅用于存储日期,格式为'YYYY-MM-DD',范围从'1000-01-01'到'9999-12-31'。
  • 优势:仅存储日期,节省存储空间。
  • 应用场景:适用于只需要记录日期而不需要时间的场景,如生日、纪念日等。

4. TIME

  • 基础概念:TIME类型仅用于存储时间,格式为'HH:MM:SS',范围从'-838:59:59'到'838:59:59'。
  • 优势:仅存储时间,适用于需要记录具体时间的场景。
  • 应用场景:适用于需要记录事件发生的具体时间而不需要日期的场景。

常见问题及解决方法

问题1:为什么使用TIMESTAMP时,时间戳会自动更新?

  • 原因:TIMESTAMP类型有一个特性,即当记录被修改时,时间戳会自动更新为当前时间。
  • 解决方法:如果不需要自动更新时间戳,可以在创建表时设置默认值和更新规则,例如:
  • 解决方法:如果不需要自动更新时间戳,可以在创建表时设置默认值和更新规则,例如:

问题2:如何处理时区问题?

  • 原因:MySQL默认使用服务器的时区,可能会导致时间显示不正确。
  • 解决方法:可以在连接数据库时设置时区,例如:
  • 解决方法:可以在连接数据库时设置时区,例如:
  • 或者在创建表时指定时区:
  • 或者在创建表时指定时区:

参考链接

希望这些信息对你有所帮助!如果有更多问题,请随时提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL时间类型差异

文章目录[隐藏] 时间格式化 DATETIME TIMESTAMP DATE TIME YEAR 日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 DATETIME 8 bytes YYYY-MM-DD...CURRENT_TIMESTAMP 默认值,创建自动插入时间 TIMESTAMP TIMESTAMP 用于表示 年月日 时分秒,但是记录的年份(见上表)比较短暂,TIMESTAMP列必须有默认值,默认值可以为...TIMESTAMP 的属性受 Mysql 版本和服务器 SQLMode 的影响较大。 如果记录的日期需要让不同时区的人使用,最好使用 TIMESTAMP。...注:一般建表时候,创建时间用datetime,更新时间用timestamp。...如果实际应用只保存年份,那么用 1 bytes 保存 YEAR 类型完全可以。不但能够节约存储空间,还能提高表的操作效率

2.6K20
  • MySQL中数字类型、数值类型、时间类型

    本文链接:https://blog.csdn.net/weixin_38004638/article/details/96135519 一、数字类型 类型 范围 说明 Char(...2是能存储的最小显示长度,如果插入的数据不够2位时,需要在数据前面用0补满2位。比如定义一个age字段,其数据类型为int(4),那用select查询出来的结果是“0002”。...int占4个字节,tinyint占1个字节,如果存储一个较小的数,用tinyint性能更高一点。 2.5 什么时候用int,什么时候用tinyint?...如果数字较小比如用01表示性别,可以用tinyint。可是,如果数字可能会超过255,则只能使用int。...三、日期时间 类型 范围 说明 Date 日期(yyyy-mm-dd) Time 时间(hh:mm:ss) DateTime 日期与时间組合(yyyy-mm-dd hh:mm:

    3.1K20

    【mysql】日期与时间类型

    MySQL有多种表示日期和时间的数据类型,不同的版本可能有所差异,MySQL8.0版本支持的日期和时间类型主要有:YEAR类型、TIME类型、DATE类型、DATETIME类型和TIMESTAMP类型。...为什么时间类型 TIME 的取值范围不是 -23:59:59~23:59:59 呢?...原因是 MySQL 设计的 TIME 类型,不光表示一天之内的时间,而且可以用来表示一个时间间隔,这个时间间隔可以超过 24 小时。 1....如果向TIMESTAMP类型的字段插入的时间超出了TIMESTAMP类型的范围,则MySQL会抛出错误信息。 举例: 创建数据表,表中包含一个TIMESTAMP类型的字段ts。...虽然 MySQL 也支持 YEAR(年)、 TIME(时间)、DATE(日期),以及 TIMESTAMP 类型,但是在实际项目中,尽量用 DATETIME 类型。

    4.2K20

    MySQL日期和时间类型笔记

    最近在看《MySQL技术内幕:SQL编程》并做了笔记,这是一篇笔记类型博客,分享出来方便自己复习,也可以帮助其他人 一、日期时间类型所占空间对比 各种日期时间数据类型所占的空间: 类型 所占空间 DATETIME...注意: 更新表时,可以设置TIMESTAMP类型的列,自动更新时间为当前时间 列为TIMESTAMP的日期类型可以设置一个默认值,而DATETIME不支持 例子,验证一下,设置默认值和自动更新时间...; # 删一下表数据 DELETE FROM t; # 写初始化数据 INSERT INTO t SELECT 1,CURRENT_TIMESTAMP; # 查询,先记录下原来时间 SELECT * FROM...四、YEAR和TIME类型对比 YEAR类型占用1字节,书中介绍定义时可以指定显示的宽度为YEAR(2)或者YEAR(4),不过在我的mysql版本5.7+验证,发现只能定义为YEAR或者YEAR(4)...函数 介绍一下MySQL比较常用的NOW、CURRENT_TIMESTAMP和SYSDATE函数 给个例子,用sleep函数,然后对比sleep函数执行前后,这几个函数获取的时间对比 SELECT NOW

    1.8K10

    MySQL 中的日期时间类型

    日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0。...通过设置 MySQL 相关参数,日期类型可保存原本非法的值,比如开启 ALLOW_INVALID_DATES 设置项时,可设置日期类型保存一个 2009-11-31 值,但正常情况下我们知道 11 月哪来什么...比如给一个日期格式的列设置 10:11:12,虽然这个值看起来像时间类型,但还是可以正确在被解析成目标列的格式,即日期。...指定 ON UPDATE CURRENT_TIMESTAMP 来使相应的日期时间列自动更新。 两者可同时作用于一个日期时间列,表示插入记录时自动初始化成当前时间,后续记录更新时自动更新到当前时间。...对于指定了自动初始化的列,插入时如果没指定该列的值,则会自动设置为当前的时间。 对于指定为自动更新的列,一旦一条记录中有字段变更,该日期会自动更新成变更时的时间。

    6.8K20

    mysql 字段时间类型的比较

    字段的时间类型分为: ,,,,; 下面就分别介绍这几种时间类型的区别 每个时间类型都有一个有效范围和一个零值,当指定的类型的值超过有效范围时,就会使用零值 YEAR 该类型表示年,格式为 有三种表示方法...:分:秒,尽管时间范围为0~23,但是为了表示某些特殊的时间,mysql将小时的范围扩大了,并且支持负值。....我们可以通过获取当前的值 DATE 该类型表示年-月-日,标准格式为,但是中还支持一些不严谨的格式:比如等其他的符号来分割 在插入数据的数据的也可以使用 年份的转换和上面的类型的规则一样的 可以使用...函数获取当前的值 DATETIME 该类型表示YYYY-MM-DD hh:mm:ss,可以看出和类型的结合体.所以赋值的规则时和上面和的时一样的 TIMESTAMP 该类型表示为YYYY-MM DD hh...哈哈,到年后就别用这个类型了 这只是一个简单的区分说明,具体时间类型的说明 请参考 官方文档 https://dev.mysql.com/doc/refman/5.7/en/date-and-time-types.html

    4.7K80

    MySQL数据类型--日期时间

    在这一路学习过来,每次不管看书还是网上看的资料,对于MySQL数据类型中的时间日期类型总是一扫而过,不曾停下来认认真真的研究学习。...最近在图书馆借了一本关于MysQL的书籍,打算全面的学习研究一遍。   在之前,我对于时间日期数据类型不怎么感冒,也没怎么用过这一类型。...二、时间日期数据类型总概况    MySQL中有多种表示时间日期的数据类型,主要有YEAR、TIME、DATE、DATETIME、TIMESTAMP等。...这是因为这个类型不仅仅可以用于存储一天的某个时间还可以记录一段时间的间隔。所以小时就24小时。插入数据可以有多种格式。 常见插入格式解析:   a、"D HH:MM:SS"格式字符串格式。...四、小结   了解MySQL的日期时间数据类型对于选取一种适合存储类型是很有必要的。

    3.3K20

    Mysql 时间类型精度截取的bug

    mysql-connector-java版本升级出现的一次问题。涉及到了时间精度的截取和四舍五入。 首先了解一点,timestamp,datetime如果不指定精度,默认的精度是秒。...举个例子:在db建表时没指定精度时,插入精确到毫秒级别的日期 如果使用mysql-connector-java版本用'2018-04-02 23:59:59.999'插入日期,...server端会对超出精度位数的数据进行四舍五入,即插入db里是'2018-04-03 00:00:00 ' 所以说mysql-connector-java版本升级就带了时间与原本不一致的问题,结合具体业务逻辑上的使用...end_time) values('2018-04-02 23:59:59','2018-04-02 23:59:59.999'); select * from time_test; 看一下记录...Mysql对于时间精度的处理在com.mysql.jdbc.PreparedStatement#setTimestampInternal这个方法中 翻一下5.1.21的源码看一下: private void

    2.9K20

    mysql 关于时间类型的刨坑之路

    问题背景 前两天有做一个基于binglog的数据库实时同步,一张老数据表里有DATETIME、TIMESTAMP不同的时间字段类型,看起来值都是一样的,并且默认值都设置的 0000-00-00 00:00...由于本人之前一直习惯使用int存储时间戳(问题相对比较少,容易处理),所以对这几个时间字段类型了解不是很多. 后来参考了今天分享的这篇文档,终于有了一个基本的认识。 ?...中文方面优秀的文档有很多,为什么还要发这篇骚扰别人. ?...TIMESTAMP 和 DATETIME 类型提供了自动初始化和更新当前的日期和时间。...MySQL interprets two-digit year values using these rules: 日期里面用两位数表示年的值是模糊的因为不知道是哪个世纪。

    1.7K30

    MySQL 时间类型 DATE、DATETIME和TIMESTAMP

    MySQL converts TIMESTAMP values from the current time zone to UTC for storage, and back from UTC to the...查询命令 show variables like '%time_zone%'; 上述“CST”指的是MySQL所在主机的系统时间,是中国标准时间的缩写,China Standard Time UT...4.TIMESTAMP在新旧版本上的重大区别 TIMESTAMP 在mysql 5.6.5之后,TIMESTAMP(fraction)中的fraction代表的是小数位数,即默认秒,以秒为单位的小数点位数...TIMESTAMP(fraction)中fraction值显示尺寸的格式如下表所示: 列类型 显示格式 TIMESTAMP(14) YYYYMMDDHHMMSS TIMESTAMP(12) YYMMDDHHMMSS...YYYYMMDD TIMESTAMP(6) YYMMDD TIMESTAMP(4) YYMM TIMESTAMP(2) YY 就版本中“完整”TIMESTAMP格式是14位,但TIMESTAMP列也可以用更短的显示尺寸

    2.9K30

    【MySQL笔记】数字类型、时间和日期类型、字符串类型

    MySQL数据库提供了多种数据类型,其中包括数字类型、时间和日期类型、字符串类型。...,实际保存在记录中的是顺序编号,而不是列表的值,因此不必担心过长的值占用空间。...SET和ENUM的区别:SET可以从列表中选择一个或多个值来保存,多个值之间用逗号“,”分隔。 SET和ENUM相似之处 1、ENUM类似单选框,SET类似复选框。...BINARY类型的长度是固定的,如果数据的长度不足最大长度,将在数据的后面用“\0”补齐,最终达到指定长度。...注意:在查询BINARY类型时,查询条件字符串需要加上“\0”填充符,否则查询不到该记录 BLOB类型 BLOB类型用于保存数据量很大的二进制数据,如图片、PDF文档等。

    4.1K20

    MySQL数据类型 -- 日期时间型

    https://blog.csdn.net/robinson_0612/article/details/82824107 在MySQL关系型数据库中,MySQL支持的数据类型非常丰富。...它主要分为3大类,即:数值型,日期时间性,字符型。而实际上这三类数据类型可以进一步的细分扩展,可以根据业务需要选择最适合的一种。本文主要介绍日期时间类型,并演示其用法。...一、日期时间型 MySQL支持的日期时间类型可以进一步细分,即可以分为日期型,时间型,日期时间型,时间戳等。如下图所示: ? 二、日期时间型存储需求 ? 三、日期时间型零值显示 ?...='+7:00'; Query OK, 0 rows affected (0.00 sec) -- 再次查看表,col4列上的时间则提前了一小时 -- 也即是时区会影响时间戳列 mysql> SELECT...-- 查看当前时间 mysql> SET @dt = NOW(); Query OK, 0 rows affected (0.03 sec) mysql> SELECT @dt; +---------

    88620

    【重学 MySQL】五十七、日期与时间类型

    【重学 MySQL】五十七、日期与时间类型 在MySQL中,日期与时间类型用于存储和操作日期和时间数据。这些类型根据所需存储的信息的精确度和范围而有所不同。...YEAR类型 用途:用于存储年份。 格式:通常为4位字符串或数字(YYYY),但MySQL也支持2位年份格式(YY),不过这种格式已经不推荐使用。...YEAR默认格式就是YYYY,没必要写成YEAR(4),从MySQL 8.0.19开始,不推荐使用指定显示宽度的YEAR(4)数据类型。 TIME类型 用途:用于存储时间,不包含日期部分。...MySQL允许“不严格”语法,任何标点符号都可用作日期部分或时间部分之间的间隔符。 TIMESTAMP类型 用途:用于存储日期和时间,与DATETIME类型类似,但支持时区转换。...虽然 MySQL 也支持 YEAR(年)、 TIME(时间)、DATE(日期),以及 TIMESTAMP 类型,但是在实际项目中,尽量用 DATETIME 类型。

    15110
    领券