在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