共计 4587 个字符,预计需要花费 12 分钟才能阅读完成。
本篇内容介绍了“MySQL 获取时间、格式转换各类操作的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让丸趣 TV 小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
一、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()
获取当地具体日期和时间:
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 表格:
该列类型为 BIGINT:
下面直接用 cast 转换为时间类型:
select cast(time as date) as timefrom value_test
可见如果有与其他 format 不对应,只记录到月或者记录到小时时,将不能识别转为时间类型。也可以切换成 time 或是 datetime:
select cast(time as datetime) as timefrom value_test
select cast(time as time) as timefrom value_test
只要是有 6 个字符的都会被识别为 %H:%M:s。
我们可以修改表再看:
2.convert()
基础语法格式:
convert(数据 , 数据类型)
select CONVERT(time ,date) as timefrom value_test
和上述 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
这个函数自由性要比 cast 和 convert 的自由性高很多,可以自由定义 format,但是不会仅显示单个年或日,后面会根据字符的长度补零填充:
select str_to_date(time, %Y) as timefrom value_test
这里我们可以更改表格的时间观察是否不满足或者超过标准的时间格式能够被识别:
select str_to_date(time, %Y%m%d) as timefrom value_test
select str_to_date(time, %Y%m%d%H%i%S) as timefrom value_test
可见兼容能力是很强的。
如果是时间都是统一格式记录的直接使用 cast 或者 convert 快速转换为时间格式就好了,若是记录的有多个维度的时间应该使用 str_to_date 函数来转换。
四、时间转换
时间转换一般是把时间类似数据转换为其他类型数据,以上例子 cast()函数和 convert()函数都可以做到。改变一下位置就好了,由于上述已经提到这里就做两个简单的例子展示:
1.cast()
select cast(create_time as signed) as timefrom value_test
2.convert()
select convert(create_time ,signed) as timefrom value_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 位
自己大家可自己随意组合使用:
select date_format(create_time, %x%v) as timefrom value_test
但是记住转换输出的都为字符串,转换为其他类型都需要再次转换.
“MySQL 获取时间、格式转换各类操作的方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注丸趣 TV 网站,丸趣 TV 小编将为大家输出更多高质量的实用文章!