hive中nvl()和coalesce()区别
nvl 和 coalesce是HSQL 中常用的空值处理函数,今天给大家聊聊这两个函数的使用细节。
第一、nvl()函数使用方法
nvl 函数语法 nvl(默认值,表达式); 如果默认值为不为空返回默认值,默认值为空 返回 表达式值如果两者都为空返回空只能传两个参数。
使用时需注意:默认值,表达式的值数据类型没有要求,可相同可不同。
如: nvl (a,b) ,若a为空,返回b,若a为非空返回a.
第二、coalesce()函数使用方法
函数语法为 coalesce(表达式1,表达式2....表达式n); coalesce函数的返回结果是第一个非空表达式,如果全是空则,返回空。处理参数个数没有限制。
使用时需注意:对处理参数的数据类型有严格要求,所有表达式值是同一类型(转换同一类型亦可)。
如: nvl (a,b,c) ,若a为空,返回b,若b为空返回c.
总结
nvl: 支持两个参数。其本质是个函数
·coalesce: 如果第一个参数为空就取第二个参数的值,以此类推,支持多个参数。更常用,更像i语句效率更高,建议使用。
练习数据准备
先建表插入两条测试数据,
create table tmp.sm_test_nvl_coalesce as ( c1 int, c2 int, c3 int, c4 int, c5 int )
insert into tmp.sm_test_nvl_coalesce value(nvl,2,nvl,nvl,4)
insert into tmp.sm_test_nvl_coalesce value(3,5,nvl,nvl,6)
关注公众号「水沐教育科技」,在手机上阅读所有教程,随时随地都能学习。内含一款搜索神器,免费下载全网书籍和视频。

微信扫码关注公众号