将 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 字段
以上,问题解决。