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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值