美文网首页
Hive中各种日期格式转换方法总结

Hive中各种日期格式转换方法总结

作者: 数据人阿多 | 来源:发表于2021-10-22 18:26 被阅读0次

背景

日期计算平时在业务取数时经常涉及到,但是数据库中经常存放着不同的日期格式,有的存放是时间戳、有的是字符串等,这时需要对其进行转换才能提取到准确的数据,这里介绍的均是hive里面的函数功能,以下内容均是业务的数据需求经常使用的部分

时间戳

unix时间戳是从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒,一般为10位的整数

一个在线工具:https://tool.lu/timestamp/

时间戳

字符串日期
如:'2021-10-21 19:25:50','2021-10-21 20:25:50.0','2021-10-21 20:25'

日期格式转换

时间戳--->正常的日期格式

  • 获取当前时间戳
select unix_timestamp()
  • 把时间戳转为正常的日期
select from_unixtime(unix_timestamp(),'yyyy-MM-dd hh:mm:ss') as dt
  • 业务中有时存放的是包含毫秒的整数,需要先转换为秒
select from_unixtime(cast(create_time/1000 as bigint),'yyyyMMdd') as dt

字符串日期
假如数据库存放的是格式为:"yyyy-MM-dd hh:mm:ss"

  • 截取日期部分
select substr('2021-10-22 17:34:56',1,10)
2021-10-22
  • 字符串强制转换,获取日期
select to_date('2021-10-22 17:34:56')
2021-10-22
  • 也可以通过date_format实现
select date_format('2021-10-22 17:34:56','yyyy-MM-dd')
2021-10-22

系统当前日期

  • 当前日期
select current_date();
2021-10-22
  • 字符串日期与系统当前日期比较,这个在业务中经常有用到
select substr('2021-10-22 17:34:56',1,10)>current_date()
false

前一日/昨日

select date_sub(current_date(),1);
2021-10-21

前一日12点/昨日12点
在业务中与截取的字符串日期进行比较时用

select concat(date_format(date_sub(current_date(),1),'yyyy-MM-dd'),' ','12');
2021-10-21 12

最近一个月/30天

select date_sub(current_date(),30);
2021-09-22

当月第一天
业务中经常用在滚动计算当月每日的业绩数据

select date_format(to_date(trunc(current_date(),'MM')),"yyyy-MM-dd");
2021-10-01

日期格式转换 yyyyMMdd--->yyyy-MM-dd

select from_unixtime(unix_timestamp('20211022','yyyyMMdd'),"yyyy-MM-dd");
2021-10-22

两个日期相隔天数

select datediff('2021-10-22', '2021-10-01');
21

历史相关文章


以上是自己实践中遇到的一些问题,分享出来供大家参考学习,欢迎关注微信公众号:DataShare ,不定期分享干货

相关文章

  • Hive中各种日期格式转换方法总结

    背景 日期计算平时在业务取数时经常涉及到,但是数据库中经常存放着不同的日期格式,有的存放是时间戳、有的是字符串等,...

  • 高频的HIVE查询相关SQL

    高频用到的HIVE查询相关SQL 1 HIVE中,字段是String的时间戳转换为日期格式语句公式:select ...

  • Hive Sql最常用的时间处理类,全在这里了

    hive 常用日期格式转换 把固定日期转换成时间戳 把 29/May/2020:11:30:03 +0800 转成...

  • Hive—date函数详解

    引言   在hive中我们经常需要处理日期数据,hive内置了3个日期函数,其格式只能为yyyy-MM-dd格式或...

  • 参数绑定

    原始方法获取表单数据 参数绑定 post乱码解决方法 jsp页面中设置date的显示格式 日期格式转换 请求方法限定

  • hive中的日期处理

    hive自带的时间/日期处理函数 将某种格式的时间转换为Unix时间戳select unix_timestamp(...

  • hive时间函数

    hive日期函数函数用法含参方式用法备注 date2datekeydate格式转换成datekeydate2dat...

  • Hive中两种日期格式的转换

    第一种方法:from_unixtime+unix_timestamp 第二种方法:substr + concat

  • js时间戳与日期格式的相互转换

    今天看到个小文章总结一下js中时间戳与日期格式的相互转换,如果有用的话就搜藏一下; 将时间戳转换成日期格式:fun...

  • hive yyyyMMdd转yyyy-MM-dd

    在hive中,我们经常需要进行日期的计算,可是,经常会出现这样一种情况,hive仓库中日期的存储格式是yyy...

网友评论

      本文标题:Hive中各种日期格式转换方法总结

      本文链接:https://www.haomeiwen.com/subject/udfxaltx.html