hive 查询表,返回数据全是null

本文探讨了在Hive中创建表并加载数据时,如何正确设置数据分隔符以避免查询结果出现全NULL的问题。通过对比不同分隔符设置下查询结果的差异,强调了数据分隔符一致性的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

### Hive 查看结构的方法 在 Hive 中,可以通过特定的命令来查看的结构。这些命令能够帮助用户理解的设计以及字段的相关属性。 #### 使用 `DESCRIBE` 命令 `DESCRIBE` 是最常用的命令之一,用于显示指定中的列及其数据类型。此命令可以提供关于的基本元数据信息[^1]。 ```sql DESCRIBE table_name; ``` 例如,如果要查看名为 `tmp_bucket` 的结构,则执行如下语句: ```sql DESCRIBE tmp_bucket; ``` 这将返回的所有字段名称、对应的数据类型以及其他附加信息(如注释)。对于引用中提到的 `tmp_bucket` 定义,其输出可能类似于以下内容[^2]: | Column | Type | Comment | |--------|---------|---------| | id | INT | NULL | | name | STRING | NULL | #### 扩展描述:`DESCRIBE FORMATTED` 为了获取更详细的信息,包括分区详情、存储格式、位置路径等,可以使用扩展版本的 `DESCRIBE FORMATTED` 命令。这种形式不仅提供了基本的列信息,还包含了更多高级配置选项[^3]。 ```sql DESCRIBE FORMATTED table_name; ``` 继续以上述例子为例,运行下面这条指令即可获得完整的数据视图: ```sql DESCRIBE FORMATTED tmp_bucket; ``` 除了常规的字段外,还会额外展示诸如桶数量 (`clustered by`) 和文件存储方式等内容。 #### 完整示例代码 以下是结合上述两种方法的一个综合实例演示: ```sql -- 创建测试用 CREATE TABLE IF NOT EXISTS test_table ( user_id BIGINT, username STRING COMMENT '用户名', created_at TIMESTAMP ) COMMENT '这是一个示例' PARTITIONED BY (dt STRING); -- 查询简单结构 DESCRIBE test_table; -- 获取面信息 DESCRIBE FORMATTED test_table; ``` 通过这种方式,不仅可以直观地看到每列的具体设置情况,还能进一步掌握整个对象背后的技术细节。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值