导入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 字段

以上,问题解决。

你可能感兴趣的:(Hive)