文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2022-11-30 23:46

关注

本篇内容介绍了“MySQL获取时间、格式转换各类操作的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、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.当业务需求中需要精确到秒时,可以用这个时间格式。

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

3.time

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

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

4.timestamp

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

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

PS.datetime与timestamp的区别

对比总结

5.varchar/bigint

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

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

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

二、获取时间

1.now()

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

select now() as time

2.localtime()

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

select LOCALTIME() as time

3.current_timestamp()

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

select current_timestamp() as time

4.localtimestamp()

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

select LOCALTIMESTAMP() as time

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

5.sysdate()

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

select sysdate() as time

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


6.curdate()

获取当地具体日期:

select curdate() as time

7.current_time()

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

select current_date() as time

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


8. curtime()

获取具体的时间:

select curtime() as time

9.current_time()

获取具体的时间:

select current_time() as

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


10. utc_date()

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

select utc_date() as time

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

11.utc_time

获取UTC时间的时间。

select utc_time() as time

12.utc_timestamp()

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

select utc_timestamp() as time

以上为获取UTC时间函数。


13.HOUR(SYSDATE())

获取系统具体小时:

select HOUR(SYSDATE()) as time

14.MINUTE(SYSDATE())

获取当前系统分钟:

select MINUTE(SYSDATE()) as time

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

三、转换时间

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

1.cast()

基础语法格式:

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

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

例如我们拿到展示的sql表格:MySQL获取时间、格式转换各类操作的方法是什么

该列类型为BIGINT:

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

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

select cast(time as date) as timefrom value_test

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

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

select cast(time as datetime) as timefrom value_test

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

select cast(time as time) as timefrom value_test

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

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

我们可以修改表再看:

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

2.convert()

基础语法格式:

convert(<数据>,<数据类型>)
select CONVERT(time ,date) as timefrom value_test

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

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

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

3.str_to_date()

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

基础语法格式:

str_to_date(<字符串>,<format格式>')
select str_to_date(time,'%Y%m%d') as timefrom value_test

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

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

select str_to_date(time,'%Y') as timefrom value_test

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

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

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

select str_to_date(time,'%Y%m%d') as timefrom value_test

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

select str_to_date(time,'%Y%m%d%H%i%S') as timefrom value_test

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

可见兼容能力是很强的。

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

四、时间转换

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

1.cast()

select cast(create_time as signed) as timefrom value_test

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

2.convert()

select convert(create_time ,signed) as timefrom value_test

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

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 位

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

select date_format(create_time, '%x%v') as timefrom value_test

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

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

“MySQL获取时间、格式转换各类操作的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯