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

MySQL 日期时间类型怎么选?千万不要乱用!

构建数据库程序避免不了使用日期和时间,对于数据库来说,有多种日期时间字段可供选择,如 timestamp 和 datetime 以及使用 int 来存储 unix timestamp。...不仅新手,包括一些有经验的程序员还是比较迷茫,究竟我该用哪种类型来存储日期时间呢?...用户前端输入的时间一般都是日期类型,如果存储 int 还需要存前取后处理 总结 timestamp 记录经常变化的更新 / 创建 / 发布 / 日志时间 / 购买时间 / 登录时间 / 注册时间等,并且是近来的时间...有没有一个时间类型即解决了范围、时区的问题?这是不可能的,不是还有 tinyInt BigInt 吗?取自己所需,并且 MySQL 是允许数据库字段变更的。...关注公众号Java技术栈回复m36可以获取一份MySQL开发军规。 欢迎大家补充和指正。

2.9K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql】日期与时间类型

    MySQL有多种表示日期和时间的数据类型,不同的版本可能有所差异,MySQL8.0版本支持的日期和时间类型主要有:YEAR类型、TIME类型、DATE类型、DATETIME类型和TIMESTAMP类型。...原因是 MySQL 设计的 TIME 类型,不光表示一天之内的时间,而且可以用来表示一个时间间隔,这个时间间隔可以超过 24 小时。 1....| f1 | f2 | +------+------+ | 2021 | 2022 | +------+------+ 1 rows in set (0.00 sec) 建议不要写两位,直接四位...如果向TIMESTAMP类型的字段插入的时间超出了TIMESTAMP类型的范围,则MySQL会抛出错误信息。 举例: 创建数据表,表中包含一个TIMESTAMP类型的字段ts。...虽然 MySQL 也支持 YEAR(年)、 TIME(时间)、DATE(日期),以及 TIMESTAMP 类型,但是在实际项目中,尽量用 DATETIME 类型

    4.2K20

    MySQL日期和时间类型笔记

    最近在看《MySQL技术内幕:SQL编程》并做了笔记,这是一篇笔记类型博客,分享出来方便自己复习,也可以帮助其他人 一、日期时间类型所占空间对比 各种日期时间数据类型所占的空间: 类型 所占空间 DATETIME...类型介绍 TIMESTAMP占4个字节,显示的范围为“1970-01-01”UTC 到 “2038-01-19 03:14:07”UTC 备注:UTC:协调世界时间、又称世界统一时间、世界标准时间和国际协调时间...注意: 更新表时,可以设置TIMESTAMP类型的列,自动更新时间为当前时间 列为TIMESTAMP的日期类型可以设置一个默认值,而DATETIME不支持 例子,验证一下,设置默认值和自动更新时间...四、YEAR和TIME类型对比 YEAR类型占用1字节,书中介绍定义时可以指定显示的宽度为YEAR(2)或者YEAR(4),不过在我的mysql版本5.7+验证,发现只能定义为YEAR或者YEAR(4)...,也就是新版是不支持YEAR(2)这种形式的 对于YEAR(4),其显示年份的范围为1901~2155;然后超过这个范围的话,mysql还可以,不过被赋值为0000 TIME类型只占3字节,显示的范围为

    1.8K10

    MySQL 中的日期时间类型

    日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0。...TIMESTAMP 类型是个例外,给它设置一个超出范围的值时,将保存上该类型允许的最大值。...在需要使用数字的语境下,MySQL 会将日期时间自动转成数字。同理,在需要日期时间的相关操作语境下,会尝试将数字解析成日期时间。...通过设置 MySQL 相关参数,日期类型可保存原本非法的值,比如开启 ALLOW_INVALID_DATES 设置项时,可设置日期类型保存一个 2009-11-31 值,但正常情况下我们知道 11 月哪来什么...比如给一个日期格式的列设置 10:11:12,虽然这个值看起来像时间类型,但还是可以正确在被解析成目标列的格式,即日期。

    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.6K80

    MySQL数据类型--日期时间

    在这一路学习过来,每次不管看书还是网上看的资料,对于MySQL数据类型中的时间日期类型总是一扫而过,不曾停下来认认真真的研究学习。...最近在图书馆借了一本关于MysQL的书籍,打算全面的学习研究一遍。   在之前,我对于时间日期数据类型怎么感冒,也没怎么用过这一类型。...在我的做项目里用到存贮时间的数据,我都是采用int整型数据类型来存储,即是存储时间戳。但是在后面学习MySQL优化的时候,就有一个原则就是存储数据时应采用最小占用空间的数据类型。...二、时间日期数据类型总概况    MySQL中有多种表示时间日期的数据类型,主要有YEAR、TIME、DATE、DATETIME、TIMESTAMP等。...四、小结   了解MySQL的日期时间数据类型对于选取一种适合存储类型是很有必要的。

    3.3K20

    当陈述需求时间 > 代码时间,我该怎么办?

    前几天在一个群聊里,有几个小伙伴讨论了一个话题: 一个活应该是同事干 但是我与他沟通,把需求明确清晰地传达给他,花费的时间 > 我这个代码的时间 那么我应该如何做?...业务也不难,我自己就做了吧.之前我也是这样,一帮总是帮到底,大家讨论后,现在想想,这样不好~ 如果这个同事是你的小帮手,但是水平比你差一些,那我觉得这种人还是应该多帮帮,甚至在完成这个任务后,还可以多花一些时间来多提醒指点他...并且同一个任务,每个程序猿思路都不完全相同,所以代码想分享的话,感觉更重要的是文档,同样的阅读自己一年前的代码可能随着经验的积累很难记得自己当时怎么想的,而文档就简单直白多了.与其争论代码好不好,倒不如好好写文档...想想我自己,我本身自己的代码的一般,在代码的稳定性,代码的安全性上应该都比较差,一直也在学习别人的代码,也一直想努力的把自己的代码写好,但是怎么算足够好,怎么衡量,真的是不知道,很多职位比我高的领导,...感觉他们的代码也是很傻,但是他们对业务,对架构那些东西的理解确实是让我很佩服的。

    54220

    mysql如何获取当前时间_mysql怎么获取当前时间「建议收藏」

    mysql获取当前时间的方法:可以通过执行【select now();】语句来获取当前时间。...获得当前日期+时间(date + time)函数:now()mysql> select now(); +———————+ | now() | +———————+ | 2008-08-08 22:20:46...| +———————+ 获得当前日期+时间(date + time)函数:sysdate() sysdate() 日期时间函数跟 now() 类似,不同之处在于:now() 在执行开始时值就得到了,...看下面的例子就明白了:mysql> select now(), sleep(3), now(); +———————+———-+———————+ | now() | sleep(3) | now() |...获得当前时间戳函数:current_timestamp, current_timestamp()mysql> select current_timestamp, current_timestamp()

    14.1K20

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

    问题背景 前两天有做一个基于binglog的数据库实时同步,一张老数据表里有DATETIME、TIMESTAMP不同的时间字段类型,看起来值都是一样的,并且默认值都设置的 0000-00-00 00:00...由于本人之前一直习惯使用int存储时间戳(问题相对比较少,容易处理),所以对这几个时间字段类型了解不是很多. 后来参考了今天分享的这篇文档,终于有了一个基本的认识。 ?...TIMESTAMP 和 DATETIME 类型提供了自动初始化和更新当前的日期和时间。...MySQL将 TIMESTAMP 的值从当前时区转换成UTC进行存储,并且会从UTC转成当前时区进行检索(这样就不会发生出现别的类型例如DATETIME)。...MySQL 对指定字符串的值的格式要求比较宽松,在date部分和时间部份可以使用任何标点符号作为定界符。在一些事例中,这样的语法可以欺骗你。

    1.7K30

    MySQL 时间类型 DATE、DATETIME和TIMESTAMP

    (2)对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。...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

    2.9K30
    领券