hive 空值、NULL判断

hive中空值判断基本分两种
(1)NULL 与 \N
hive在底层数据中如何保存和标识NULL,是由 alter table name SET SERDEPROPERTIES('serialization.null.format' = '\N'); 参数控制的
好比:
1.设置 alter table name SET SERDEPROPERTIES('serialization.null.format' = '\N'); 
则:底层数据保存的是'\N',经过查询显示的是'NULL'
这时若是查询为空值的字段可经过 语句:a is null 或者 a='\\N'
 
          2.设置 alter tablename SET SERDEPROPERTIES('serialization.null.format' = 'NULL'); 
则:底层数据保存的是'NULL',经过查询显示的是'NULL'
这时若是查询为空值的字段可经过 语句:a is null 或者 a='NULL'
(2)'' 与 length(xx)=0
'' 表示的是字段不为null且为空字符串,此时用 a is null 是没法查询这种值的,必须经过 a=''  或者 length(a)=0 查询