Hive的条件函数与日期函数全面汇总解析

本文详述了Hive的条件函数如assert_true、coalesce等,以及日期函数如add_months、current_date等,提供了每个函数的解释和实例,是Hive函数查询的实用参考。
摘要由CSDN通过智能技术生成

Hive的开窗函数实战的文章中,主要介绍了Hive的分析函数的基本使用。本文是这篇文章的延续,涵盖了Hive所有的条件函数和日期函数,对于每个函数,本文都给出了具体的解释和使用案例,方便在工作中查阅。

条件函数

assert_true(BOOLEAN condition)

  • 解释

如果condition不为true,则抛出异常,否则返回null

  • 使用案例
select assert_true(1<2) -- 返回null
select assert_true(1>2) -- 抛出异常

coalesce(T v1, T v2, …)

  • 解释

返回第一个不为null的值,如果都为null,则返回null

  • 使用案例
select coalesce(null,1,2,null)  -- 返回1
select coalesce(1,null) -- 返回1
select coalesce(null,null) -- 返回null

if(BOOLEAN testCondition, T valueTrue, T valueFalseOrNull)

  • 解释

如果testCondition条件为true,则返回第一个值,否则返回第二个值

  • 使用案例
select if(1 is null,0,1)  -- 返回1
select if(null is null,0,1) -- 返回0

isnotnull(a)

  • 解释

如果参数a不为null,则返回true,否则返回false

  • 使用案例
select isnotnull(1) -- 返回true
select isnotnull(null) -- 返回false

isnull(a)

  • 解释

与isnotnull相反,如果参数a为null,则返回true,否则返回false

  • 使用案例
select isnull(null) -- 返回true
select isnull(1) -- 返回false

nullif(a, b)

  • 解释

如果参数a=b,返回null,否则返回a值(Hive2.2.0版本)

  • 使用案例
select nullif(1,2) -- 返回1
select nullif(1,1) -- 返回null

nvl(T value, T default_value)

  • 解释

如果value的值为null,则返回default_value默认值,否则返回value的值。在null值判断时,可以使用if函数给定默认值,也可以使用此函数给定默认值,使用该函数sql特别简洁。

  • 使用案例
select nvl(1,0) -- 返回1
select nvl(null,0) -- 返回0

日期函数

add_months(DATE|STRING|TIMESTAMP start_date, INT num_months)

  • 解释

start_date参数可以是string, date 或者timestamp类型,num_months参数时int类型。返回一个日期,该日期是在start_date基础之上加上num_months个月,即start_date之后null_months个月的一个日期。如果start_date的时间部分的数据会被忽略。注意:如果start_date所在月份的天数大于结果日期月的天数,则返回结果月的最后一天的日期。

  • 使用案例
select add_months("2020-05-20",2); -- 返回2020-07-20
select 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值