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


    目录

    前言

    一、SQL时间存储类型

    1.date

    2.datetime

    3.time

    4.timestamp

    PS.datetime与timestamp的区别

    对比总结

    5.varchar/bigint

    二、获取时间

    1.now()

    ?2.localtime()

    ?3.current_timestamp()

    4.localtimestamp()

    5.sysdate()

    ?6.curdate()

    7.current_time()

    8.?curtime()

    9.current_time()

    10.?utc_date()

    11.utc_time

    ??编辑

    12.utc_timestamp()

    ?13.HOUR(SYSDATE())

    ?14.MINUTE(SYSDATE())

    三、转换时间?

    1.cast()?

    ?2.convert()

    3.str_to_date()

    四、时间转换

    1.cast()?

    2.convert()?

    ?3.date_format()

    点关注,防走丢,如有纰漏之处,请留言指教,非常感谢

    参阅:



    前言

    时间在数据库中经常作为时间索引,在数据入库和出库以及更新的时候都需要变化。在一些指标计算或者是提取某段时间的数据时,都会根据数据库中的时间索引数据进行操作。因此很大一部分我们操作数据都得先从时间数据下手,但是想要真正提取到我们想要的时间作为索引,还需要我们掌握许多功能函数方便我们操作,这是一个比较复杂的运用过程。因此特地写下这篇文章,记录一些十分好用常用的处理数据库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的区别

    1. 存储方式不同,对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不做任何改变,基本上是原样输入和输出.
    2. 存储的时间范围也不一样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’。
    3. timestamp有一个机制是自动初始化与更新,意思就是如果插入数据的时候没有对该值进行赋值,则自动写入当前的时间戳对应的格式。在更新其他字段的时候该自动会自动更新到当前的时间

    对比总结

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

    5.varchar/bigint

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

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

    二、获取时间

    1.now()

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

    select now() as time
    
    • 1

    2.localtime()

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

    select LOCALTIME() as time
    
    • 1

    3.current_timestamp()

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

    select current_timestamp() as time
    
    • 1

    4.localtimestamp()

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

    select LOCALTIMESTAMP() as time
    
    • 1

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

    5.sysdate()

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

    select sysdate() as time
    
    • 1

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


    6.curdate()

    获取当地具体日期:

    select curdate() as time
    
    • 1

    7.current_time()

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

    select current_date() as time
    
    • 1

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


    8.curtime()

    获取具体的时间:

    select curtime() as time
    
    • 1

    9.current_time()

    获取具体的时间:

    select current_time() as time
    
    • 1

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


    10.utc_date()

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

    select utc_date() as time
    
    • 1

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

    11.utc_time

    获取UTC时间的时间。

    select utc_time() as time
    
    • 1

    12.utc_timestamp()

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

    select utc_timestamp() as time
    
    • 1

    以上为获取UTC时间函数。


    13.HOUR(SYSDATE())

    获取系统具体小时:

    select HOUR(SYSDATE()) as time
    
    • 1

    14.MINUTE(SYSDATE())

    获取当前系统分钟:

    select MINUTE(SYSDATE()) as time
    
    • 1

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

    三、转换时间

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

    1.cast()

    基础语法格式:

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

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

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

    该列类型为BIGINT:

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

    select cast(time as date) as time
    from value_test
    
    • 1
    • 2

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

    select cast(time as datetime) as time
    from value_test
    
    • 1
    • 2

    select cast(time as time) as time
    from value_test
    
    • 1
    • 2

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

    我们可以修改表再看:

    2.convert()

    基础语法格式:

    convert(<数据>,<数据类型>)
    
    select CONVERT(time ,date) as time
    from value_test
    
    • 1
    • 2
    • 3
    • 4

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

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

    3.str_to_date()

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

    基础语法格式:

    str_to_date(<字符串>,')
    
    select str_to_date(time,'%Y%m%d') as time
    from value_test
    
    • 1
    • 2
    • 3
    • 4

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

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

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

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

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

    可见兼容能力是很强的。

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

    四、时间转换

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

    1.cast()

    select cast(create_time as signed) as time
    from value_test
    
    • 1
    • 2

    2.convert()

    select convert(create_time ,signed) as time
    from value_test
    
    • 1
    • 2

    3.date_format()

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

    语法格式:

    date_format(<时间类型数据>,)
    
    • 1

    其中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
    
    • 1
    • 2

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

    点关注,防走丢,如有纰漏之处,请留言指教,非常感谢

    以上就是本期全部内容。我是 ,有问题大家随时留言讨论 ,我们下期见。


    参阅:

    mysql 日期类型转换

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    牛客小白月赛73DE
    Serverless Devs 社区联合信通院邀请您参加 2022 中国 Serverless 用户调查
    基于Springboot社区人口管理系统的分析与实现
    (免费领源码)JavaWeb#Springboot#MYSQL跳蚤市场网络商城 99706-计算机毕业设计项目选题推荐
    基于隐私保护的联邦推荐算法综述
    如何使用webgl(three.js)实现煤矿隧道、井下人员定位、掘进面、纵采面可视化解决方案——第十九课(一)
    脚手架安装
    2021全球网站流量最高的网站,Python 带你看一看
    (Open Shortest Path First,OSPF)实验4
    NAACL2022 对比学习论文
  • 原文地址:https://blog.csdn.net/m0_67401746/article/details/126080841