千家信息网

Hive中null和\N怎么处理

发表于:2024-09-22 作者:千家信息网编辑
千家信息网最后更新 2024年09月22日,本篇内容主要讲解"Hive中null和\N怎么处理",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Hive中null和\N怎么处理"吧!Hive中有种假的N
千家信息网最后更新 2024年09月22日Hive中null和\N怎么处理

本篇内容主要讲解"Hive中null和\N怎么处理",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"Hive中null和\N怎么处理"吧!

Hive中有种假的NULL,它看起来和NULL一摸一样,但是实际却不是NULL。空值NULL在底层默认是用'\N'来存储的,而我们习惯性对NULL 值的过滤,一般是is null 和 is not null。所以此时可以通过对修改hive 表的信息,来保证控制都显示为指定值 ,方便进行过滤。解决方法如下:

(1)如下:

alter table t_dw_ct_author set serdeproperties ('serialization.null.format' = 'NULL');

则出现:底层数据保存的是'NULL',通过查询显示的是'NULL'

这时如果查询为空值的字段可通过 语句:a is null 或者 a='NULL'

或者

alter table t_dw_ct_author set serdeproperties('serialization.null.format' = '\N');

则出现:底层数据保存的是'\N',通过查询显示的是'NULL'

这时如果查询为空值的字段可通过 语句:a is null 或者 a='\\N'

(2)'' 与 length(xx)=0

'' 表示的是字段不为null且为空字符串,此时用 a is null 是无法查询这种值的,必须通过 a='' 或者 length(a)=0 查询

到此,相信大家对"Hive中null和\N怎么处理"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

0