码迷,mamicode.com
首页 > 其他好文 > 详细

Hive查询表,返回数据全是NULL

时间:2017-05-24 00:44:15      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:sel   需要   limit   load data   orm   path   文件   use   select   

情况1:

hive> create table users(id int, name string);

hive> load data local inpath ‘/usr/local/users.txt‘ into table users;

其中“/usr/local/users.txt”的内容为下面所示,每一行的(id,name)之间使用一个空格分割。

1 lee
2 jack
3 rose
4 marry
5 tom

hive> select * from users;
OK
NULL NULL
NULL NULL
NULL NULL
NULL NULL
NULL NULL

 

情况2:将情况1中文件“/usr/local/users.txt”的每一行(id,name)之间使用一个Tab键分割。

hive> select * from users;
OK
NULL NULL
NULL NULL
NULL NULL
NULL NULL
NULL NULL

 

情况3:将情况1中的命令

hive> create table users(id int, name string);

改为:

hive> CREATE TABLE users(id int, name string) ROW FORMAT DELIMITED FIELDS TERMINATED BY ‘ ‘ LINES TERMINATED BY ‘\n‘ STORED AS TEXTFILE;

其中TERMINATED BY ‘ ‘指定了数据分隔符是一个空格,与“/usr/local/users.txt”中每行分隔符一致。

hive> select * from users;
OK
1 lee
2 jack
3 rose
4 marry
5 tom

综上所述:hive 中创建表加载数据的时候,分隔符与加载文件中的分隔符需要一致,才能得到正确的查询结果.

 

Hive查询表,返回数据全是NULL

标签:sel   需要   limit   load data   orm   path   文件   use   select   

原文地址:http://www.cnblogs.com/followyourdream/p/6896766.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!