Hive中表达式包含空值的问题

在学习Hive过程中遇到了一个问题:如果查询语句中的表达式包含空值,会导致最终表达式结果为空值。

举一个例子,假设有一个员工表emp

namesalcomm
Jack1000200
Tony1200300
Tom1300NULL
Rose900100
Lily800500
Tim1100NULL

表中第一列是姓名,第二列是月薪,第三列是奖金

现在想获得年薪年收入,其中:

年薪 = sal * 12

年收入 = sal * 12 + comm

select name, sal * 12, sal * 12 + comm
from emp;

查询结果:

namesal * 12sal * 12 + comm
Jack1200012200
Tony1440014700
Tom15600NULL
Rose1080010900
Lily960010100
Tim13200NULL

可以看到涉及到空值的表达式无法正常表示

经过查找发现了一个解决方法:nvl函数

nvl函数: 空值转换函数

函数形式: nvl(expr1,expr2)

作用: 将查询为Null值转换为指定值

注意:

  1. 若expr1为Null,则返回expr2,否则返回expr1
  2. 适用于数字型、字符型和日期型,但是expr1和expr2的数据类型必须为相同类型
select name, sal * 12, sal * 12 + nvl(comm, 0)
from emp;

查询结果:

namesal * 12sal * 12 + comm
Jack1200012200
Tony1440014700
Tom1560015600
Rose1080010900
Lily960010100
Tim1320013200
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值