Hive查詢表,返回數據全是NULL


情況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 中創建表加載數據的時候,分隔符與加載文件中的分隔符需要一致,才能得到正確的查詢結果.

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM