大数据技术架构(组件)12——Hive:判断函数
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
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) |