玩转MySQL—各类获取时间、格式转换操作方法详解
bigegpt 2024-10-25 10:23 8 浏览
前言
时间在数据库中经常作为时间索引,在数据入库和出库以及更新的时候都需要变化。在一些指标计算或者是提取某段时间的数据时,都会根据数据库中的时间索引数据进行操作。
因此很大一部分我们操作数据都得先从时间数据下手,但是想要真正提取到我们想要的时间作为索引,还需要我们掌握许多功能函数方便我们操作,这是一个比较复杂的运用过程。
因此特地写下这篇文章,记录一些十分好用常用的处理数据库SQL时间数据的函数,以及实例运用这些函数完成一些复杂查询任务。希望能够帮助到正在看此文的各位。
一、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 time
from value_test
复制代码
可见如果有与其他format不对应,只记录到月或者记录到小时时,将不能识别转为时间类型。也可以切换成time或是datetime:
select cast(time as datetime) as time
from value_test
复制代码
select cast(time as time) as time
from value_test
复制代码
只要是有6个字符的都会被识别为%H:%M:s。
我们可以修改表再看:
2.convert()
基础语法格式:
convert(<数据>,<数据类型>)
复制代码
select CONVERT(time ,date) as time
from 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 time
from value_test
复制代码
这个函数自由性要比cast和convert的自由性高很多,可以自由定义format,但是不会仅显示单个年或日,后面会根据字符的长度补零填充:
select str_to_date(time,'%Y') as time
from value_test
复制代码
这里我们可以更改表格的时间观察是否不满足或者超过标准的时间格式能够被识别:
select str_to_date(time,'%Y%m%d') as time
from value_test
复制代码
select str_to_date(time,'%Y%m%d%H%i%S') as time
from value_test
复制代码
可见兼容能力是很强的。
如果是时间都是统一格式记录的直接使用cast或者convert快速转换为时间格式就好了,若是记录的有多个维度的时间应该使用str_to_date函数来转换。
四、时间转换
时间转换一般是把时间类似数据转换为其他类型数据,以上例子cast()函数和convert()函数都可以做到。改变一下位置就好了,由于上述已经提到这里就做两个简单的例子展示:
1.cast()
select cast(create_time as signed) as time
from value_test
复制代码
2.convert()
select convert(create_time ,signed) as time
from 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) | |
%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 位 |
自己大家可自己随意组合使用:
select date_format(create_time, '%x%v') as time
from value_test
复制代码
但是记住转换输出的都为字符串,转换为其他类型都需要再次转换。
以上就是本期全部内容。有问题大家随时留言讨论,下期见。
相关推荐
- 得物可观测平台架构升级:基于GreptimeDB的全新监控体系实践
-
一、摘要在前端可观测分析场景中,需要实时观测并处理多地、多环境的运行情况,以保障Web应用和移动端的可用性与性能。传统方案往往依赖代理Agent→消息队列→流计算引擎→OLAP存储...
- warm-flow新春版:网关直连和流程图重构
-
本期主要解决了网关直连和流程图重构,可以自此之后可支持各种复杂的网关混合、多网关直连使用。-新增Ruoyi-Vue-Plus优秀开源集成案例更新日志[feat]导入、导出和保存等新增json格式支持...
- 扣子空间体验报告
-
在数字化时代,智能工具的应用正不断拓展到我们工作和生活的各个角落。从任务规划到项目执行,再到任务管理,作者深入探讨了这款工具在不同场景下的表现和潜力。通过具体的应用实例,文章展示了扣子空间如何帮助用户...
- spider-flow:开源的可视化方式定义爬虫方案
-
spider-flow简介spider-flow是一个爬虫平台,以可视化推拽方式定义爬取流程,无需代码即可实现一个爬虫服务。spider-flow特性支持css选择器、正则提取支持JSON/XML格式...
- solon-flow 你好世界!
-
solon-flow是一个基础级的流处理引擎(可用于业务规则、决策处理、计算编排、流程审批等......)。提供有“开放式”驱动定制支持,像jdbc有mysql或pgsql等驱动,可...
- 新一代开源爬虫平台:SpiderFlow
-
SpiderFlow:新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。-精选真开源,释放新价值。概览Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台,它使用Ja...
- 通过 SQL 训练机器学习模型的引擎
-
关注薪资待遇的同学应该知道,机器学习相关的岗位工资普遍偏高啊。同时随着各种通用机器学习框架的出现,机器学习的门槛也在逐渐降低,训练一个简单的机器学习模型变得不那么难。但是不得不承认对于一些数据相关的工...
- 鼠须管输入法rime for Mac
-
鼠须管输入法forMac是一款十分新颖的跨平台输入法软件,全名是中州韵输入法引擎,鼠须管输入法mac版不仅仅是一个输入法,而是一个输入法算法框架。Rime的基础架构十分精良,一套算法支持了拼音、...
- Go语言 1.20 版本正式发布:新版详细介绍
-
Go1.20简介最新的Go版本1.20在Go1.19发布六个月后发布。它的大部分更改都在工具链、运行时和库的实现中。一如既往,该版本保持了Go1的兼容性承诺。我们期望几乎所...
- iOS 10平台SpriteKit新特性之Tile Maps(上)
-
简介苹果公司在WWDC2016大会上向人们展示了一大批新的好东西。其中之一就是SpriteKitTileEditor。这款工具易于上手,而且看起来速度特别快。在本教程中,你将了解关于TileE...
- 程序员简历例句—范例Java、Python、C++模板
-
个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...
- Telerik UI for iOS Q3 2015正式发布
-
近日,TelerikUIforiOS正式发布了Q32015。新版本新增对XCode7、Swift2.0和iOS9的支持,同时还新增了对数轴、不连续的日期时间轴等;改进TKDataPoin...
- ios使用ijkplayer+nginx进行视频直播
-
上两节,我们讲到使用nginx和ngixn的rtmp模块搭建直播的服务器,接着我们讲解了在Android使用ijkplayer来作为我们的视频直播播放器,整个过程中,需要注意的就是ijlplayer编...
- IOS技术分享|iOS快速生成开发文档(一)
-
前言对于开发人员而言,文档的作用不言而喻。文档不仅可以提高软件开发效率,还能便于以后的软件开发、使用和维护。本文主要讲述Objective-C快速生成开发文档工具appledoc。简介apple...
- macOS下配置VS Code C++开发环境
-
本文介绍在苹果macOS操作系统下,配置VisualStudioCode的C/C++开发环境的过程,本环境使用Clang/LLVM编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- resize函数 (64)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- mybatis大于等于 (64)
- xcode-select (66)
- httperror403.14-forbidden (63)
- logstashinput (65)
- hadoop端口 (65)
- dockernetworkconnect (63)
- esxi7 (63)
- vue阻止冒泡 (67)
- c#for循环 (63)
- oracle时间戳转换日期 (64)
- jquery跨域 (68)
- php写入文件 (73)
- java大写转小写 (63)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)