导入hive表Error: Error while compiling statement: FAILED: SemanticException No files matching path file

将 CSV 文件导入 hive 表时报错:

0: jdbc:hive2://10.5.145.113:10000> load data local inpath '/DATA/hdfs/example.csv' into table db.example_table ;
Error: Error while compiling statement: FAILED: SemanticException Line 1:23 Invalid path ''/DATA/hdfs/example.csv': No files matching path file:/DATA/hdfs/example.csv (state=42000,code=40000)

错误原因:

查资料表示可能原因是 文件在服务器本地的路径是'/DATA/hdfs/example.csv',需要使用 Hadoop 路径下的文件,因此将此 CSV 文件传入 Hadoop 路径下,具体如解决办法。

解决办法:

1、查 Hadoop 路径下的文件夹:

hadoop fs -ls /data/test

2、确认该路径下没有自己的文件夹,新建一个自己的文件夹:

hadoop fs -mkdir /data/test/example

3、将服务器本地的 CSV 文件上传到 Hadoop 下自己的文件夹中:

hadoop fs -put example.csv /data/test/example
# 注意此时是在服务器上执行的命令,而不是在 hive 终端,且要进入有 example.csv 文件的路径下

4、此时执行 导入命令,load  命令更改如下:

load data inpath '/data/test/example.csv' into table db.example_table;
# 注意此时命令去掉 local 字段

以上,问题解决。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值