一文速学-玩转MySQL获取时间、格式转换各类操作方法详解

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 一文速学-玩转MySQL获取时间、格式转换各类操作方法详解

一、SQL时间存储类型


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


1.date


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


99bf3618653349399c691ab722e6b3ef.png


2.datetime


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


7180d08472904e288c5afd2c34fbd47e.png



3.time


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

7bc570a5c67d49dba1521485aaa2aa3e.png


4.timestamp


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

48967b55637d4d3e83f024177714eda9.png


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


对比总结


  1. timestamp和datetime除了存储范围和存储方式不一样,没有太大区别。如果对于跨时区的业务,TIMESTAMP更为合适
  2. timestamp有自动初始化和更新,当你update某条记录的时候,该列值会自动更新,这是和datatime最大的区别


5.varchar/bigint


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

 

a0ad2ec7b2b24134b34dd60802114e40.png


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


二、获取时间


1.now()


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


select now() as time

a0d12ca835f345b78cbf66f2e8adf239.png


2.localtime()


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


select LOCALTIME() as time


f997748092174fab81f148d94f8f63ea.png


3.current_timestamp()

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


select current_timestamp() as time

13b64cfaf63c44ec869f6379b8f3e0b1.png

4.localtimestamp()


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


select LOCALTIMESTAMP() as time


9d5c6af7b0c94da98f2d6d20617fbbfd.png


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


5.sysdate()


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

select sysdate() as time

9930f513b84442c3a7a8a5a30a9251d4.png

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


6.curdate()


获取当地具体日期:


select curdate() as time


9bff46c36786474dad1e8899c706e597.png

7.current_time()


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


select current_date() as time

586076c6481d4406b436991fa82c9ae1.png

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


8. curtime()

获取具体的时间:


select curtime() as time

7fceb662b53b4f7d8173e9fddd68b35a.png

9.current_time()


获取具体的时间:


select current_time() as time

c468b7402bc646c186844ab9c79dabf2.png


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


10. utc_date()


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


select utc_date() as time


81309500f54446479b6250d240e28e44.png


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


11.utc_time


获取UTC时间的时间。


select utc_time() as time


cece6c877f9f45a3a5f25ac53b0a7b14.png

12.utc_timestamp()


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


select utc_timestamp() as time


70fd1488c66f4f4a89d001c60972e71f.png


以上为获取UTC时间函数。


13.HOUR(SYSDATE())


获取系统具体小时:


select HOUR(SYSDATE()) as time

05a3bbd65d1a4180a80f4bf8ff0d71e8.png


14.MINUTE(SYSDATE())


获取当前系统分钟:


select MINUTE(SYSDATE()) as time


e32c2f320a514eceb3d4fb258fd1cfe2.png

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


三、转换时间


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


1.cast()


基础语法格式:

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

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


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

0be7ec752a2141be8c3316291dcdcdee.png


该列类型为BIGINT:


3ba816c94c904ec59071cc94018b3241.png


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

select cast(time as date) as time
from value_test

fa5aa1b73bb2480ab2d6e91e0627c2a2.png


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

select cast(time as datetime) as time
from value_test

8e0058dd51444d9ea04948efc66010fa.png

select cast(time as time) as time
from value_test


6d55578f81d4495c950dc047fbeca2e8.png

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

我们可以修改表再看:

d87e26bd8ec94012a2e2dcb871443b7d.png


75d91c1999dd4840843e8c440bdd9be3.png


2.convert()


基础语法格式:


convert(<数据>,<数据类型>)


select CONVERT(time ,date) as time
from value_test

ee75c2e19c324e4e8d75888db0789600.png


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

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


3.str_to_date()


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

基础语法格式:

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

e6ecf29297914af68885140a40f2a1e5.png


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

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

75cf6ff7f69246abbf50ae32e1f4b6fc.png


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

0f8eebf2a5164f11b71636b4dd250626.png

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

94db601bceba422299678dda5ea615c7.png

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

03d6ba78f3244eeead09e973bc9f87d7.png

可见兼容能力是很强的。


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


四、时间转换


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


1.cast()

select cast(create_time as signed) as time
from value_test

db9879ff3cfd473d82d4194b02a1342f.png

2.convert()

select convert(create_time ,signed) as time
from value_test

8e8541bbcb6d408a93515bf02695d3fd.png


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)

%p AM 或 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 位


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


1. select date_format(create_time, '%x%v') as time
2. from value_test

c1596e55f5ea43c9b494168424399ea2.png



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

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
SQL 关系型数据库 MySQL
一文速学-玩转MySQL中INTERVAL关键字和INTERVAL()函数用法讲解
一文速学-玩转MySQL中INTERVAL关键字和INTERVAL()函数用法讲解
823 0
一文速学-玩转MySQL中INTERVAL关键字和INTERVAL()函数用法讲解
|
存储 关系型数据库 MySQL
一文速学-玩转MySQL时间运算函数以及时间匹配操作详解+实例代码
一文速学-玩转MySQL时间运算函数以及时间匹配操作详解+实例代码
281 0
一文速学-玩转MySQL时间运算函数以及时间匹配操作详解+实例代码
|
SQL 关系型数据库 MySQL
一文速学-玩转MySQL时间选取各类函数操作详解+实例代码
一文速学-玩转MySQL时间选取各类函数操作详解+实例代码
178 0
一文速学-玩转MySQL时间选取各类函数操作详解+实例代码
|
8天前
|
关系型数据库 MySQL 数据库
Python处理数据库:MySQL与SQLite详解 | python小知识
本文详细介绍了如何使用Python操作MySQL和SQLite数据库,包括安装必要的库、连接数据库、执行增删改查等基本操作,适合初学者快速上手。
71 15
|
1天前
|
SQL 关系型数据库 MySQL
数据库数据恢复—Mysql数据库表记录丢失的数据恢复方案
Mysql数据库故障: Mysql数据库表记录丢失。 Mysql数据库故障表现: 1、Mysql数据库表中无任何数据或只有部分数据。 2、客户端无法查询到完整的信息。
|
8天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
13天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
21天前
|
关系型数据库 MySQL 数据库
GBase 数据库如何像MYSQL一样存放多行数据
GBase 数据库如何像MYSQL一样存放多行数据
|
1月前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
36 1
|
1月前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
44 4