当前位置: 首页 > MySQL数据库

MySQL获取时间、格式转换各类操作的方法是什么

时间:2026-01-27 10:37:37
一、SQL时间存储类型

首先要玩好处理时间的操作,要先明白此数据类型能够干什么事,有什么用。MySQL中经常用来存储日期的数据类型有三种:Date、Datetime、Timestamp。

1.date

日历日期,例如:‘2022-6-17’.format形式为:%Y-%m-%d。在其他语言中,像Python、JAVA等利用函数输出Date都为yyyy-mm-dd的形式,业务精确到天就用这个格式。

2.datetime

具体时间日期 例如:'2022-6-17 17:00:22' format格式为:%Y-%m-%d %H:%M:%s.当业务需求中需要精确到秒时,可以用这个时间格式。

3.time

具体时间不包括日期,例如:'17:11:00' format格式为:%H:%M:%s。当业务需求中只需要每天的时间,可以用这个时间格式。

4.timestamp

和datetime存储类型一样,也是既存储时间又存储日期。format格式为:%Y-%m-%d %H:%M:%s.

PS.datetime与timestamp的区别

    存储方式不同,对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不做任何改变,基本上是原样输入和输出.

    存储的时间范围也不一样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’。

    timestamp有一个机制是自动初始化与更新,意思就是如果插入数据的时候没有对该值进行赋值,则自动写入当前的[时间戳]对应的格式。在更新其他字段的时候该自动会自动更新到当前的时间

    对比总结

      timestamp和datetime除了存储范围和存储方式不一样,没有太大区别。如果对于跨时区的业务,TIMESTAMP更为合适

      timestamp有自动初始化和更新,当你update某条记录的时候,该列值会自动更新,这是和datatime最大的区别

      5.varchar/bigint

      有时候存储入库格式不是固定的,可能出现入库时间精确到日或者是小时又可能只有月,这种灵活不固定的时间就只能使用字符串或者是BIGINT这种类型格式来进行。

      这种就需要提取出来后期处理,转换为时间格式进行计算或者进行逻辑运算得到自己想要的时间。

      二、获取时间

      1.now()

      获取当地具体日期和时间:

      selectnow()astime

      2.localtime()

      获取当地具体日期和时间,与now()一样:

      selectLOCALTIME()astime

      3.current_timestamp()

      获取当地具体日期和时间,与now()一样:

      selectcurrent_timestamp()astime

      4.localtimestamp()

      获取当地具体日期和时间,与now()一样:

      selectLOCALTIMESTAMP()astime

      以上这4种函数功能都与now()功能一样获取当地具体日期和时间,平常使用一个now()就好了好记。

      5.sysdate()

      获取当地具体日期和时间,与now()上述几个函数不一样的是,now()在执行该函数之前就已得到了。

      selectsysdate()astime

      以上函数均为获取具体日期和时间。


      6.curdate()

      获取当地具体日期:

      selectcurdate()astime

      7.current_time()

      获取当地具体日期,和curdate()函数功能一样:

      selectcurrent_date()astime

      以上函数均为获取具体日期。


      8. curtime()

      获取具体的时间:

      selectcurtime()astime

      9.current_time()

      获取具体的时间:

      selectcurrent_time()as

      以上均为获得具体时间的函数。


      10. utc_date()

      获取UTC时间的日期,因为我们是东八时区要快8个小时,本地时间=UTC时间+8小时。

      selectutc_date()astime

      由于博主现在是晚上九点所以还是6月17日,如果是早上八点之前就是6月16号了。

      11.utc_time

      获取UTC时间的时间。

      selectutc_time()astime

      12.utc_timestamp()

      获取UTC时间的具体日期和时间,在做跨国业务时非常有用。

      selectutc_timestamp()astime

      以上为获取UTC时间函数。


      13.HOUR(SYSDATE())

      获取系统具体小时:

      selectHOUR(SYSDATE())astime

      14.MINUTE(SYSDATE())

      获取当前系统分钟:

      selectMINUTE(SYSDATE())astime

      其他获取year,month,day,second,microsecond都可以通过这种方法获得,这里不再演示。

      三、转换时间

      如果是用BIGINT或者是字符串varchar存储的时间数据就需要将该列数据转换为时间数据,或者输入一个字符串想要转化为时间格式都需要转换函数,这里详细介绍各种方法解决这种问题:

      1.cast()

      基础语法格式:

      cast(<数据>as<数据类型>)

      可转换的类型有字符串varchar、日期date、时间time、日期时间datetime、浮点型decimal、整数signed、无符号整数unsigned。

      例如我们拿到展示的sql表格:

      该列类型为BIGINT:

      下面直接用cast转换为时间类型:

      selectcast(timeasdate)astimefromvalue_test

      可见如果有与其他format不对应,只记录到月或者记录到小时时,将不能识别转为时间类型。也可以切换成time或是datetime:

      selectcast(timeasdatetime)astimefromvalue_test

      selectcast(timeastime)astimefromvalue_test

      只要是有6个字符的都会被识别为%H:%M:s。

      我们可以修改表再看:

      2.convert()

      基础语法格式:

      convert(<数据>,<数据类型>)
      selectCONVERT(time,date)astimefromvalue_test

      和上述cast的功能一样,但是cast是强制转换。

      所以说如果涉及到记录有多个不同维度的时间数据存储的时候,一般是不用数据库时间类型去做存储的。看cast的例子就可以看出。

      3.str_to_date()

      str_to_date()函数可以将时间格式的字符串按照所指定的显示格式(format)转换为不同的时间类型。

      基础语法格式:

      str_to_date(<字符串>,<format格式>')
      selectstr_to_date(time,'%Y%m%d')astimefromvalue_test

      这个函数自由性要比cast和convert的自由性高很多,可以自由定义format,但是不会仅显示单个年或日,后面会根据字符的长度补零填充:

      selectstr_to_date(time,'%Y')astimefromvalue_test

      这里我们可以更改表格的时间观察是否不满足或者超过标准的时间格式能够被识别:

      selectstr_to_date(time,'%Y%m%d')astimefromvalue_test

      selectstr_to_date(time,'%Y%m%d%H%i%S')astimefromvalue_test

      可见兼容能力是很强的。

      如果是时间都是统一格式记录的直接使用cast或者convert快速转换为时间格式就好了,若是记录的有多个维度的时间应该使用str_to_date函数来转换。

      四、时间转换

      时间转换一般是把时间类似数据转换为其他类型数据,以上例子cast()函数和convert()函数都可以做到。改变一下位置就好了,由于上述已经提到这里就做两个简单的例子展示:

      1.cast()

      selectcast(create_timeassigned)astimefromvalue_test

      2.convert()

      selectconvert(create_time,signed)astimefromvalue_test

      3.date_format()

      其实最主要的还是使用data_format(),date_format()函数可以以不同的格式显示日期/时间数据,可以实现日期转换成字符串。也就是将时间数据读取之后按照format形式转换为字符串输出,当然转换为了字符串我们又可以转为其他的格式。

      语法格式:

      date_format(<时间类型数据>,<format格式>)

      其中format的格式参数可选的有:

      格式描述
      %a星期名缩写
      %b月名缩写
      %c代表几月的数值
      %D带时序后缀的数值-天
      %d天数,数值(00-31)
      %e天数,数值(0-31)
      %f微秒
      %H小时 (00-23)
      %h小时 (01-12)
      %I小时 (01-12)
      ----------------------------
      %i分钟,数值(00-59)
      %j转换为天数 (001-366)
      %k小时 (0-23)
      %l小时 (1-12)
      %M月名
      %m月,数值(00-12)
      %pAM 或 PM
      %r时间,12-小时(hh:mm:ss AM 或 PM)
      %S秒(00-59)
      %s秒(00-59)%T时间, 24-小时 (hh:mm:ss)
      -------------------------------
      %U从年初首周开始计算 (00-53) 星期日是一周的第一天
      %u从年初首周开始计算 (00-53) 星期一是一周的第一天
      %V周 (01-53) 星期日是一周的第一天,与 %X 使用
      ------------------------------
      %v周 (01-53) 星期一是一周的第一天,与 %x 使用
      %W星期名
      %w当前周的天数,(0=星期日, 6=星期六)
      %X年,其中的星期日是周的第一天,4 位,与 %V 使用
      %x年,其中的星期一是周的第一天,4 位,与 %v 使用
      ----------------------------
      %Y年,4 位
      %y年,2 位

      自己大家可自己随意组合使用:

      selectdate_format(create_time,'%x%v')astimefromvalue_test

      但是记住转换输出的都为字符串,转换为其他类型都需要再次转换.


      上一篇:mysql视图的作用是什么及怎么创建
      下一篇:为什么不要依赖MySQL高可用性进行维护
      mysql

  • 英特尔与 Vertiv 合作开发液冷 AI 处理器
  • 英特尔第五代 Xeon CPU 来了:详细信息和行业反应
  • 由于云计算放缓引发扩张担忧,甲骨文股价暴跌
  • Web开发状况报告详细介绍可组合架构的优点
  • 如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳
  • 美光在数据中心需求增长后给出了强有力的预测
  • 2027服务器市场价值将接近1960亿美元
  • 生成式人工智能的下一步是什么?
  • 分享在外部存储上安装Ubuntu的5种方法技巧
  • 全球数据中心发展的关键考虑因素
  • 英特尔与 Vertiv 合作开发液冷 AI 处理器

    英特尔第五代 Xeon CPU 来了:详细信息和行业反应

    由于云计算放缓引发扩张担忧,甲骨文股价暴跌

    Web开发状况报告详细介绍可组合架构的优点

    如何使用 PowerShell 的 Get-Date Cmdlet 创建时间戳

    美光在数据中心需求增长后给出了强有力的预测

    2027服务器市场价值将接近1960亿美元

    生成式人工智能的下一步是什么?

    分享在外部存储上安装Ubuntu的5种方法技巧

    全球数据中心发展的关键考虑因素