Hive-sql对IFNULL()函数的替换

mysql里的函数:

1.LEFT()
函数是一个字符串函数,它返回具有指定长度的字符串的左边部分。
LEFT(Str,length); LEFT(“1234”,2)
接收两个参数:str:一个字符串;length:想要截取的长度,是一个正整数;
2.IFNULL()
函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。
注:mysql里的IFNULL函数可以用hive里的if和coalesce函数替换

mysql   :  IFNULL(column,0)
hive:           if(column is null,0,column)
                  coalesce(column,0)

hive里的函数:

shiftleft(TINYINT|SMALLINT|INT a, INT b)    shiftleft(2,2)  按位左移

通用函数:

1.DATEDIFF()
函数返回两个日期之间的天数
select datediff(‘2019-09-01’,‘2019-08-30’)
2.if()
在mysql中if()函数的用法类似于java中的三目表达式,其用处也比较多,具体语法如下:
IF(expr1,expr2,expr3),如果expr1的值为true,则返回expr2的值,如果expr1的值为false,
则返回expr3的值。
if(true,1,2)
3.COALESCE()函数
该函数主要用来进行空值处理,其参数格式如下:
COALESCE (value1,value2……,valuen)
从左至右依次判断是否为null,返回第一个不是null的值,如果找不到返回null

你可能感兴趣的:(hive学习)