Hive-函数-时间处理

在Hive中,处理时间数据的函数非常有用,尤其是在处理包含时间戳或日期字段的大数据时。以下是一些Hive中相对频繁使用的时间处理函数,包括它们的名称、参数、功能以及SQL示例。

1. from_unixtime

  • 参数bigint unixtime, [string format]

  • 功能 :将Unix时间戳(秒)转换为指定格式的字符串。如果未指定格式,则默认为yyyy-MM-dd HH:mm:ss

  • SQL示例

    sql 复制代码
    SELECT from_unixtime(unix_timestamp(), 'yyyy-MM-dd HH:mm:ss') AS formatted_time;

2. unix_timestamp

  • 参数[string date], [string pattern]

  • 功能:将字符串(日期)转换为Unix时间戳(秒)。如果未指定日期字符串,则返回当前时间的Unix时间戳。如果指定了模式(pattern),则按该模式解析日期字符串。

  • SQL示例

    sql 复制代码
    SELECT unix_timestamp('2023-04-01 12:00:00', 'yyyy-MM-dd HH:mm:ss') AS timestamp_seconds;

3. date_format

  • 参数string date, string format

  • 功能:将日期/时间字符串按照指定的格式进行格式化。

  • SQL示例

    sql 复制代码
    SELECT date_format('2023-04-01 12:00:00', 'yyyy-MM-dd') AS formatted_date;

4. to_date

  • 参数string timestamp

  • 功能 :将时间戳字符串转换为日期(yyyy-MM-dd)格式。

  • SQL示例

    sql 复制代码
    SELECT to_date('2023-04-01 12:00:00') AS date_only;

5. current_datecurrent_timestamp

  • 参数:无

  • 功能current_date 返回当前日期(yyyy-MM-dd),而 current_timestamp 返回当前的日期和时间(包括时区信息,如果配置了的话)。

  • SQL示例

    sql 复制代码
    SELECT current_date AS today, current_timestamp AS now;

6. date_add

  • 参数string startdate, int days

  • 功能:在日期上加上指定的天数。

  • SQL示例

    sql 复制代码
    SELECT date_add('2023-04-01', 10) AS new_date;

7. date_sub

  • 参数string startdate, int days

  • 功能:从日期中减去指定的天数。

  • SQL示例

    sql 复制代码
    SELECT date_sub('2023-04-11', 10) AS previous_date;

8. datediff

  • 参数string enddate, string startdate

  • 功能:计算两个日期之间的天数差。

  • SQL示例

    sql 复制代码
    SELECT datediff('2023-04-11', '2023-04-01') AS days_between;

9. yearmonthdayhourminutesecond

  • 参数string date

  • 功能:分别提取日期时间字符串中的年、月、日、小时、分钟、秒部分。

  • SQL示例

    sql 复制代码
    SELECT year('2023-04-01 12:00:00') AS year, month('2023-04-01 12:00:00') AS month;

相关推荐
码字的字节8 小时前
深入解析Hadoop RPC:技术细节与推广应用
hadoop·rpc
码字的字节8 小时前
深入解析Hadoop架构设计:原理、组件与应用
大数据·hadoop·分布式·hadoop架构设计
LucianaiB14 小时前
AI 时代的分布式多模态数据处理实践:我的 ODPS 实践之旅、思考与展望
大数据·数据仓库·人工智能·分布式·odps
༺水墨石༻18 小时前
低版本hive(1.2.1)UDF实现清除历史分区数据
数据仓库·hive·hadoop
Leo.yuan2 天前
数据清洗(ETL/ELT)原理与工具选择指南:企业数字化转型的核心引擎
大数据·数据仓库·数据挖掘·数据分析·etl
isNotNullX2 天前
实时数仓和离线数仓还分不清楚?看完就懂了
大数据·数据库·数据仓库·人工智能·数据分析
熊猫钓鱼>_>2 天前
Hadoop 用户入门指南:驾驭大数据的力量
大数据·hadoop·分布式
William一直在路上2 天前
SpringBoot 拦截器和过滤器的区别
hive·spring boot·后端
Leo.yuan2 天前
数据分析师如何构建自己的底层逻辑?
大数据·数据仓库·人工智能·数据挖掘·数据分析
抛砖者3 天前
hive/spark sql中unix_timestamp 函数的坑以及时间戳相关的转换
hive·sql·spark