大数据技术架构(组件)12——Hive:判断函数

文章详细介绍了Hive中的几个重要判断和逻辑处理函数,如if,isnull,isnotnull,nvl,coalesce以及casewhen。这些函数在数据处理中用于检查NULL值、执行条件判断和提供默认值。例如,if函数根据条件返回不同值,isnull和isnotnull检测NULL,nvl和coalesce则用于处理NULL值,而casewhen允许更复杂的条件分支判断。
摘要由CSDN通过智能技术生成

1.4.6、判断函数

1.4.6.1、if

select if(1=1,'a','b'),if(1=2,'a','b') ;

1.4.6.2、isnull

select isnull(1),isnull(null);

1.4.6.3、isnotnull

select isnotnull(1),isnotnull(null);

1.4.6.4、nvl

select nvl(1,1),nvl(null,1);

1.4.6.5、coalesce

select coalesce(1,null,2,3,null,4,null),coalesce(null,null,null,2,3,4),coalesce(null,null,null,null);

1.4.6.6、case when

select case when 1=1 then '1' else 'b' end ,case when 1=1 then '1' end;

1.4.6.7、nullif -->Hive2.3.0

1.4.6.8、assert_true --> Hive0.8.0

 select assert_true(1=1),assert_true(1=2);

支持版本

返回值类型

函数名称

功能描述

T

if(boolean testCondition, T valueTrue, T valueFalseOrNull)

当 testCondition 为真时返回 valueTrue,否则返回 valueFalseOrNull

boolean

isnull( a )

如果 a 为 NULL,则返回 true,否则返回 false。

boolean

isnotnull ( a )

如果 a 不是 NULL,则返回 true,否则返回 false。

T

nvl(T value, T default_value)

如果值为 null 则返回默认值,否则返回值(从 Hive 0.11 开始)

T

COALESCE(T v1, T v2, ...)

返回第一个不是 NULL 的 v,如果所有 v 都是 NULL,则返回 NULL。

T

CASE a WHEN b THEN c [WHEN d THEN e]* [ELSE f] END

当 a = b 时,返回 c;当 a = d 时,返回 e;否则返回 f

T

CASE WHEN a THEN b [WHEN c THEN d]* [ELSE e] END

当 a = true 时,返回 b;当 c = true 时,返回 d;否则返回 e。

Hive2.3.0

T

nullif( a, b )

如果 a=b,则返回 NULL;否则返回一个(从 Hive 2.3.0 开始)。简写:CASE WHEN a = b then NULL else a

Hive0.8.0

void

assert_true(boolean condition)

如果“条件”不为真,则抛出异常,否则返回 null(从 Hive 0.8.0 开始)。例如,选择 assert_true (2<1)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

mylife512

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值