• 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 ' ' 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 中创建表加载数据的时候,分隔符与加载文件中的分隔符需要一致,才能得到正确的查询结果.

  • 相关阅读:
    EnumMap实现类
    java enum
    openssl生成RSA公钥和私钥对
    rsa 公钥 私钥
    eclispe 通过git向码云上传
    eclipse git 报 git: 401 Unauthorized
    HttpClient 超时时间
    HttpClient 4 和 HttpClient 3 超时
    Java RSA 生成公钥 私钥
    万能适配器
  • 原文地址:https://www.cnblogs.com/followyourdream/p/6896766.html
Copyright © 2020-2023  润新知