sqoop导出hive数据到mysql避免空值

sqoop导入导出问题

sqoop export --connect jdbc:mysql://ip:3306/eqpt_base_db?characterEncoding=utf8 --username root --password secret_password --table A_JQZ_T_GAS_GET_ORDER_NUM_INFO_S  --export-dir  /user/hive/warehouse/origin_ennenergy_energytrade.db/a_jqz_t_gas_get_order_num_info_s  --input-null-string '\\N' --input-null-non-string '\\N' --fields-terminated-by '\t'

为了避免空值时,没有数据,需要以下命令:

--input-null-string '\\N' --input-null-non-string '\\N' --fields-terminated-by '\t'

由sqoop导入失败发现的hive的空值问题

先说基础知识
hive中空值分两种
(1)NULL
hive中null实际在HDFS中默认存储为'\N',通过查询显示的是'NULL'。

这时如果查询为空值的字段可通过语句:aaa is null 或者 aaa ='\N' 实现。
此时可用hive中与null有关的函数,如nvl,coalesce,is null等判断是否为null是为true。

产生NULL值,一般都是由hive外链接引起的。

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

产生''值,一般都是源数据为空。

之前项目中用到sqoop工具从HDFS中往数据库中导数据时,任务失败。不得已,用二分法导数据,去排查问题,看看是哪一条数据导致任务报错。最后排查到数据文件中有字段的值为空。但是奇怪的是,在hive sql里面已经加为null判断了。再看数据文件,发现其中的值不是通常的NULL,或者是\N,而是''。

所以得到原因,用判断null的nvl函数并不能排除''的情况,需要用IF(aaa == '','未知',aaa) AS aaa 来判断。

 
 

猜你喜欢

转载自www.cnblogs.com/18800105616a/p/12603980.html