viewing Hive Conditional Functions with Examples" width="2056" height="1157" />
Hive conditional functions are used to apply conditions on one or more columns and the conditions are executed for every row on a table.
AdvertisementsIn this article, you will learn Hive conditional functions isnull, isnotnull, nvl, nullif, case when e.t.c with examples.
Select the link to know more about the function along with examples.
Conditional Function | Description |
---|---|
isnull( a ) | This returns a true when the value of a (column) is NULL otherwise it returns false. Return: boolean |
isnotnull ( a ) | This returns a true when the value of a (column) is NOT NULL otherwise it returns false. Return: boolean |
If(boolean testCondition, T valueTrue, T valueFalseOrNull) | Similar to IF condition existing on SQL queries. This returns valueTrue when testCondition is true, otherwise returns valueFalseOrNull Return: T |
nvl(T value, T default_value) | This replaces all null values of column T with the default value. Return: T |
COALESCE(T v1, T v2, …) | Returns the first v that is not NULL, or NULL if all v’s are NULL. Return: T |
CASE a WHEN b THEN c [WHEN d THEN e]* [ELSE f] END | This is similar to the switch statement where when a = b, returns c; when a = d, returns e; else returns f. Return: T |
CASE WHEN a THEN b [WHEN c THEN d]* [ELSE e] END | When a = true, returns b; when c = true, returns d; else returns e. Return: T |
nullif( a, b ) | Returns NULL if a=b; otherwise returns a (as of Hive 2.3.0). Shorthand for: CASE WHEN a = b then NULL else a Return: T |
assert_true(boolean condition) | When the condition is true it does nothing but when it is false it throws an exception Though this function says it doesn’t return anything, when the value is true it returns NULL. Return: void |
Before we jump into examples, first, let’s create a Hive table.
CREATE TABLE IF NOT EXISTS employee ( id int, name string, age int, gender string, salary decimal ) COMMENT 'Employee Table' ROW FORMAT DELIMITED FIELDS TERMINATED BY ',';
Create a records.csv file @ /tmp folder with the following data. To make it simple I have created this file in my local file system, not HDFS.
1,James,30,M,10000 2,Ann,40,F,20000 3,Jeff,41,M,30000 4,Jennifer,20,F,40000 5,Kum,30,M, 7,Jeni.
Load into the table using the below command.
jdbc:hive2://> LOAD DATA LOCAL INPATH '/tmp/record.csv' INTO TABLE employee; jdbc:hive2://> SELECT * FROM employee; +--------------+----------------+---------------+------------------+------------------+ | employee.id | employee.name | employee.age | employee.gender | employee.salary | +--------------+----------------+---------------+------------------+------------------+ | 1 | James | 30 | M | 10000 | | 2 | Ann | 40 | F | 20000 | | 3 | Jeff | 41 | M | 30000 | | 4 | Jennifer | 20 | F | 40000 | | 5 | Kum | 30 | M | NULL | | 7 | Jeni | NULL | | NULL | +--------------+----------------+---------------+------------------+------------------+ 6 rows selected (0.149 seconds)
Now let’s get into action with examples.
This returns a true when the value of a (column) is NULL otherwise it returns false.
Syntax: isnull(column)
0: jdbc:hive2://> SELECT salary,isnull(salary) FROM employee . . . . . . . . > WHERE gender='M'; OK +---------+--------+ | salary | _c1 | +---------+--------+ | 10000 | false | | 30000 | false | | NULL | true | +---------+--------+
Above example column _C1 is derived based on salary column, if you notice isnull() function return true for value NULL and false for non NULL values.
This returns a true when the value of a (column) is NOT NULL otherwise it returns false.
Syntax: isnotnull(column)
0: jdbc:hive2://> SELECT salary,isnotnull(salary) FROM employee . . . . . . . . > WHERE gender='M'; OK +---------+--------+ | salary | _c1 | +---------+--------+ | 10000 | true | | 30000 | true | | NULL | false | +---------+--------+
Similar to IF condition existing on SQL queries. This returns valueTrue when testCondition is true, otherwise returns valueFalseOrNull
Syntax: if(boolean testCondition, T valueTrue, T valueFalseOrNull)
0: jdbc:hive2://> SELECT salary,if(isnull(salary),'No Salary','Present Salary') . . . . . . . . > FROM employee WHERE gender='M'; OK +---------+-----------------+ | salary | _c1 | +---------+-----------------+ | 10000 | Present Salary | | 30000 | Present Salary | | NULL | No Salary | +---------+-----------------+
This replaces all null values of a column T with the default value.
Syntax: nvl(T value, T default_value)
0: jdbc:hive2://> SELECT salary,Nvl(salary,-1) FROM employee . . . . . . . . > WHERE gender='M'; OK +---------+--------+ | salary | _c1 | +---------+--------+ | 10000 | 10000 | | 30000 | 30000 | | NULL | -1 | +---------+--------+
Returns the first v that is not NULL, or NULL if all v’s are NULL.
Syntax: COALESCE(T v1, T v2, . )
//TO-DO
This is similar to switch statement where when a = b, returns c; when a = d, returns e; else returns f.
Syntax: CASE a WHEN b THEN c [WHEN d THEN e]* [ELSE f] END
0: jdbc:hive2://> SELECT salary,CASE salary WHEN 10000 THEN 1 . . . . . . . . > WHEN 30000 THEN 2 . . . . . . . . > ELSE 0 . . . . . . . . > END . . . . . . . . > FROM employee where gender='M'; OK +---------+------+ | salary | _c1 | +---------+------+ | 10000 | 1 | | 30000 | 2 | | NULL | 0 | +---------+------+
If you are familiar with Spark, you can read Spark CASE WHEN and WHEN OTHERWISE example
When a = true, returns b; when c = true, returns d; else returns e.
Syntax: CASE WHEN a THEN b [WHEN c THEN d]* [ELSE e] END
0: jdbc:hive2://> select salary,gender, . . . . . . . . > case when salary=10000 then 1 . . . . . . . . > when gender='M' then 2 . . . . . . . . > else '-1' END . . . . . . . . > from employee where gender = 'M'; OK +---------+---------+------+ | salary | gender | _c2 | +---------+---------+------+ | 10000 | M | 1 | | 30000 | M | 2 | | NULL | M | 2 | +---------+---------+------+ 3 rows selected (0.167 seconds)
Returns NULL if a=b; otherwise returns a (as of Hive 2.3.0).
Shorthand for: CASE WHEN a = b then NULL
Syntax: nullif( a, b )
0: jdbc:hive2://> select nullif(1,1); OK +-------+ | _c0 | +-------+ | NULL | +-------+ 1 row selected (0.144 seconds) 0: jdbc:hive2://> select nullif(1,2); OK +------+ | _c0 | +------+ | 1 | +------+ 1 row selected (0.168 seconds)
When the condition is true it does nothing but when it is false it throws an exception
Though this function says it doesn’t return anything, when the value is true it returns NULL.
Syntax: assert_true(Boolean Condition)
jdbc:hive2://> select assert_true(true); jdbc:hive2://> select assert_true(false);// returns exception jdbc:hive2://> select assert_true(1==2);// returns exception