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)

关注公众号「水沐教育科技」,在手机上阅读所有教程,随时随地都能学习。内含一款搜索神器,免费下载全网书籍和视频。

公众号二维码
微信扫码关注公众号

微信交流群 关注微信公众号,加入官方交流群。内含一款搜索神器,免费下载全网书籍和视频。