SQL中日期格式处理方法大全

 更新时间:2023年09月06日 10:50:46   作者:Forge_ahead  
这篇文章主要给大家介绍了关于SQL中日期格式处理方法的相关资料,在SQL中日期格式化非常重要的,因日期SQL中的一个基数据类型,我们可以使用函数和选项来格式化日期,使用日期函数来处理日期数据,需要的朋友可以参考下

背景:

实际工作,使用SQL语句对数据进行处理,有一大部分工作是对日期时间型数据进行处理,通过对字段的拼接或转换生成实际需要的格式的日期字段。本文章尽可能全面记录现在主流的数据库(MySQL和Hive)对日期格式的处理,形成一份工作速查文档,提升工作效率。

一、获取当前日期

MySQL

select now();  --日期时间格式
select current_date();  -- 日期格式
select current_time(); -- 时间格式
select sysdate();  -- 日期时间格式
select current_timestamp();  -- 日期时间戳

Hive

select current_date()  -- 日期格式
select current_timestamp()  -- 日期时间格式

sql server

select getdate()
--获得年月日
select convert(nvarchar(10),getdate(),120)
--获得年月
select convert(nvarchar(7),getdate(),120)

二、日期格式化

格式化可以将不符合要求规范的日期格式字段或字符串类型字段转换为格式化日期。

MySQL

select  date_format('20230613','%Y-%m-%d');
select  date_format('20230613','%Y-%m-%d %H:%i:%s');
select  date_format(now(),'%Y-%m-%d');
-- 可使用unix_timestamp函数获取 unix 时间戳,使用时间格式转换函数from_unixtime转换为格式日期
select from_unixtime(unix_timestamp('20230613'), '%Y-%m-%d');

Hive

select date_format(current_timestamp(),'yyyy-MM-dd')  
-- Hive中对月份格式用MM
select date_format(current_timestamp(),'yyyy-MM-dd HH:mm:ss')
select from_unixtime(unix_timestamp('2023-06-13', 'yyyy-MM-dd'), 'yyyyMMdd') -- 生成20230613对应格式的日期
-- unix_timestamp返回对应时间戳
select unix_timestamp() -- 返回当前时间对应的时间戳,时间戳数值可以加减,如一小时3600秒,一天86400秒

sql server

select convert(datetime,'YYYY-MM-DD   HH24:MI:SS')
-- cast强制转换
select cast('YYYY-MM-DD   HH24:MI:SS'   as   datetime)

三、日期转换为字符串

SQL表中存储日期对数据类型有要求,特别是 hive存储日期时间的时候通常用string,所以有时也要实现日期转换为字符串。

MySQL

-- 可使用substr字符串切割函数,返回从m开始长度为n的字符串
select substr(now(),1,10);
-- 使用concat字符串拼接函数
select concat(substr(now(),1,4),substr(now(),6,2));

Hive

-- 使用cast强制转换为字符串
select cast(from_unixtime(unix_timestamp('20230613', 'yyyyMMdd'), 'yyyy-MM-dd') as string)

sql server

-- 
select convert(nvarchar(10),getdate(),120)
-- 常用格式
Select  CONVERT(varchar(100), GETDATE(), 120)   -- 年月日 时分秒
Select CONVERT(varchar(100), GETDATE(), 112)   -- 年月日(无分隔符)
Select CONVERT(varchar(100), GETDATE(), 111)  -- 年月日(分隔符/)
Select CONVERT(varchar(100), GETDATE(), 102)  -- 年月日(分隔符.)
Select CONVERT(varchar(100), GETDATE(), 23)  -- 年月日(分隔符-)
Select CONVERT(varchar(100), GETDATE(), 8)  -- 时分秒

日期计算

在表的实际计算中,常需要计算距离某个日期或现在日期往前或往后某段时间的日期。

-- 加(Mysql)
select date_add(now(),interval 1 day);
-- year:年,quarter:季,month:月,week:周,day:天,hour:小时,minuter:分钟,second:秒,microsecond:毫秒
-- 加(sql server)
select dateadd(day,n,'2023-06-20')
-- 加(Hive)
select date_add(current_timestamp(),1) -- 加一天
select date_format(date_sub(current_timestamp(),1),'yyyy-MM-dd') --指定前一天日期
select from_unixtime((unix_timestamp()-86400),'yyyy-MM') --指定前一天日期
-- 减
select date_sub(now(),interval 1 month);
select date_sub(date_format(current_timestamp(),'yyyy-MM-dd'),1) 
select date_sub(current_timestamp(),14) -- Hive指定前一天日期
-- 计算日期间隔
select datediff('2023-6-16','2023-6-1') -- mysql计算两个日期之间的间隔(相差天数)
select datediff('d','2023-6-1','2023-6-16 12:20:00') --sql server计算两个日期之间间隔天数
select timediff('12:00:00', '11:30:00') -- 两个时间间隔
select timestampdiff(month,date_sub(now(),interval 60 day),now()); -- 相差月
-- timestampdiff第一个参数定义返回计算的结果。year:年,quarter:季,month:月,week:周,day:天,hour:小时,minuter:分钟,second:秒,microsecond:毫秒
-- timestampdiff减去的日期带有时间,会认为是下一天(2023-07-20 08:00:00会按照2023-07-21计算);datediff会直接截取时间(2023-07-20 18:00:00也会按照2023-07-20计算)
select timestampdiff(day,'2023-07-13',current_date()) -- timestampdiff可以实现各种字符串(例如2023-07-13,20230703)日期的加减
-- 当月的第一天
select STR_TO_DATE(CONCAT(DATE_FORMAT(now(),'%Y-%m'), '-01'), '%Y-%m-%d')
-- sql server返回当月1号
select CONVERT(varchar(10),DATEADD(MONTH,DATEDIFF(MONTH,0,GETDATE()),0),120)
-- 当月最后一天
select DATE_ADD(STR_TO_DATE(CONCAT(DATE_FORMAT(DATE_ADD(now(),INTERVAL 1 MONTH),'%Y-%m'), '-01'), '%Y-%m-%d'),INTERVAL -1 DAY); 

总结 

到此这篇关于SQL中日期格式处理的文章就介绍到这了,更多相关SQL日期格式处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SQL注入漏洞扫描之sqlmap详解

    SQL注入漏洞扫描之sqlmap详解

    SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入
    2025-01-01
  • 如何使用navicat远程连接openGauss

    如何使用navicat远程连接openGauss

    公司要在openEuler系统中安装openGauss数据库,经过几天的查资料,终于是安装成功了,并且能在navicat中远程连接使用,本文给大家介绍如何使用navicat远程连接openGauss,感兴趣的朋友跟随小编一起看看吧
    2023-10-10
  • 主键与聚集索引

    主键与聚集索引

    表通常具有包含唯一标识表中每一行的值的一列或一组列。这样的一列或多列称为表的主键 (PK),用于强制表的实体完整性。在创建或修改表时,您可以通过定义 PRIMARY KEY 约束来创建主键。
    2009-07-07
  • 数据库的四种隔离级别

    数据库的四种隔离级别

    今天小编就为大家分享一篇关于数据库的四种隔离级别,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • MSSQL转MYSQL的一些记录

    MSSQL转MYSQL的一些记录

    今天把一个MSSQL的数据库转成MYSQL,在没有转换工具的情况下,对于字段不多的数据表我用了如下手功转换的方法,还算方便。MSSQL使用企业管理器操作,MYSQL用phpmyadmin操作。
    2010-02-02
  • mysql、mssql及oracle分页查询方法详解

    mysql、mssql及oracle分页查询方法详解

    这篇文章主要介绍了mysql、mssql及oracle分页查询方法,实例分析了数据库分页的实现技巧,非常具有实用价值,需要的朋友可以参考下
    2015-04-04
  • 将sqlite3中数据导入到mysql中的实战教程

    将sqlite3中数据导入到mysql中的实战教程

    最近因为工作的需求,需要将sqlite3中的数据导入到mysql中去,发现网上的一些教程都不够详细,索性自己写一篇,下面这篇文章主要给大家介绍了关于将sqlite3数据库中的数据导入到mysql数据库中的相关资料,需要的朋友可以参考下。
    2017-07-07
  • 数据库同步优化技巧分享

    数据库同步优化技巧分享

    这篇文章主要介绍了数据库同步优化技巧分享,需要的朋友可以参考下
    2015-10-10
  • Instagram提升PostgreSQL性能的五个技巧

    Instagram提升PostgreSQL性能的五个技巧

    这篇文章主要介绍了Instagram提升PostgreSQL性能的五个技巧,Instagram的数据库一直由PostgreSQL支撑,经验很具有参考性,需要的朋友可以参考下
    2015-04-04
  • 分布式数据存储系统的三要素

    分布式数据存储系统的三要素

    大家好,本篇文章主要讲的是分布式数据存储系统的三要素,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2021-12-12

最新评论