Hive 查询报错:Hive is not a Parquet file

当从textfile格式的业务库拉取数据到指定为Parquet格式的Hive表时,出现expectedmagicnumber错误。原因是数据格式不匹配。解决方法是在创建Hive表时明确指定存储格式为textfile。
摘要由CSDN通过智能技术生成

Hive is not a Parquet file. expected magic number at tail [80, 65, 82, 49] but found [48,46, 48,10]

背景

当从业务库拉取数据到Hive后,执行select * from {table} 时报如下错误:

hive is not a Parquet file. expected magic number at tail [80, 65, 82, 49] but found [48,46, 48,10]

原因

Hive存储形式:textfile、sequencefile、Parquet

业务库是 textfile 格式,大数据在建表时指定为Parquet格式,所以数据拉取过来会出现错误。

解决

在建表时明确定义存储形式

create table test.test1
(
    user_id    string     COMMENT '用户id'
)
comment '测试'
partitioned by (d string)
stored as textfile
location '/opt/user/hive/warehouse/test/test1'
;

单纯个人记录和分享, 希望得到支持和鼓励。

如果对您有帮助,可以点赞评论鼓励一下!

如果有更优的的建议或方法,可以在评论区留下见解!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值