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)  -- 时分秒

日期计算

在表的实际计算中,常需要计算距离某个日期或现在日期往前或往后某段时间的日期。文章来源地址https://www.toymoban.com/news/detail-584476.html

-- 加(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 add_months('2022-07-16', n) -- Hive加n个月份
select date_format(date_sub(current_timestamp(),1),'yyyy-MM-dd') --指定前一天日期
select from_unixtime((unix_timestamp()-86400),'yyyy-MM') --指定前一天日期
-- Gbase指定前一天日期
select subdate(current_date,interval 1 day) 
-- 减
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,Hive计算两个日期之间的间隔(相差天数)
select datediff('d','2023-6-1','2023-6-16 12:20:00') --sql server计算两个日期之间间隔天数
select months_between('2023-09-22','2022-07-16') -- Hive计算两个日期之间的间隔
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)日期的加减
-- 计算小时差(Hive)
select datediff(date1,date2)*24 + (hour(date1)-hour(date2))

-- 当月的第一天
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中日期格式处理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • SQL Server中Convert函数转换日期的用法 日期格式化

    convert函数: 作用: convert()函数是把日期转换为新数据类型的通用函数。 convert() 函数可以用不同的格式显示日期/时间数据。 语法: CONVERT(data_type(length),expression,style) 参数:data_type(length):目标数据类型(长度) expression:需要转换的数据 style:规定日期/时间的输出格式 style规

    2024年02月06日
    浏览(61)
  • [22007] [Microsoft][ODBC Driver 17 for SQL Server][SQL Server]从字符串转换日期和/或时间时,转换失败。 (241)过滤非法日期格式数据

    出现这个错误是因为你在SQL Server中尝试将一个无效的字符串转换为日期或时间格式。为了解决这个问题,你需要过滤掉不合法的数据。 你可以使用TRY_CONVERT函数来尝试将字符串转换为日期或时间格式,如果转换失败,则返回NULL。然后你可以使用IS NOT NULL来过滤掉这些NULL值。

    2024年02月08日
    浏览(85)
  • 1/50 hive sql 日期处理函数

    目录 一、获取当前时间 二、获取指定时间 三、转换时间格式 【1】to_date(string timestamp) 【2】date_format(date string timestamp,string format) 【3】from_unixtime(bigint unixtime,string format) 【4】unix_timestamp(date string timestamp,string pattern)  【5】其余格式的指定转换 regexp_replace()、from_unixtime(unix_ti

    2023年04月25日
    浏览(46)
  • SQL 日期处理和视图创建:常见数据类型、示例查询和防范 SQL 注入方法

    在数据库操作中,处理日期是一个关键的方面。确保插入的日期格式与数据库中日期列的格式匹配至关重要。以下是一些常见的SQL日期数据类型和处理方法。 DATE - 格式为YYYY-MM-DD DATETIME - 格式为YYYY-MM-DD HH:MI:SS TIMESTAMP - 格式为YYYY-MM-DD HH:MI:SS YEAR - 格式为YYYY或YY DATE - 格式为YY

    2024年02月05日
    浏览(58)
  • SQL Server日期时间字符串的处理和转换

    在SQL Server中,您可以使用T-SQL函数进行日期时间字符串的处理和转换。要判断一个日期字符串是否包含时间信息,可以使用T-SQL内置的函数CONVERT和TRY_CONVERT,并指定时间格式。 例如,假设有一个名为date_string的日期字符串,您可以使用以下代码来判断它是否包含时间信息: 如

    2024年02月16日
    浏览(49)
  • 在SQL中,可以使用不同的函数来转换字符串日期格式。以下是一些常用的函数:

    1. STR_TO_DATE(): 将字符串转换为日期格式。它接受两个参数:要转换的字符串和日期格式。 示例: 这将把字符串 ‘2023-07-04’ 转换为日期格式,并返回结果作为 converted_date。 2. CAST(): 将字符串转换为日期格式。它接受两个参数:要转换的字符串和目标数据类型。 示例: 这将把

    2024年02月04日
    浏览(59)
  • Spark SQL 时间格式处理

    1.current_date和current_timestamp  current_date :取得当前日期 current_timestamp : 取得当期时间日期 current_timestamp() : 这个函数用于获取当前的日期和时间戳。 year(col(\\\"local_date\\\")) : 这个函数会提取出\\\"local_date\\\"列中的年份。 month(col(\\\"local_date\\\")) : 这个函数会提取出\\\"local_date\\\"列中的月份。 quart

    2024年02月03日
    浏览(27)
  • 【MySql】 深入理解SQL中的日期处理:NVL和TIMESTAMPDIFF函数的应用

    还有多少个十年 能勇敢做热血青年 还有多少个十年 能坚持当初的信念 还有多少个十年 能不忘怀回忆点点                      🎵 《还有多少个十年》 在处理数据库时,日期和时间的操作是日常任务中最常见且关键的部分之一。无论是过滤数据、生成报告还是执

    2024年04月25日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包