0

我刚开始学习 pig 并试图用它做点什么,所以我进入 pig 控制台并简单地输入a = load 'sample_data.csv';(我有一个名为 的文件sample_data.csv)。我收到以下异常:

Pig Stack Trace
---------------
ERROR 2998: Unhandled internal error. name

java.lang.NoSuchFieldError: name
    at org.apache.pig.parser.QueryParserStringStream.<init>(QueryParserStringStream.java:32)
    at org.apache.pig.parser.QueryParserDriver.tokenize(QueryParserDriver.java:207)
    at org.apache.pig.parser.QueryParserDriver.parse(QueryParserDriver.java:175)
    at org.apache.pig.PigServer$Graph.validateQuery(PigServer.java:1571)
    at org.apache.pig.PigServer$Graph.registerQuery(PigServer.java:1544)
    at org.apache.pig.PigServer.registerQuery(PigServer.java:516)
    at org.apache.pig.tools.grunt.GruntParser.processPig(GruntParser.java:991)
    at org.apache.pig.tools.pigscript.parser.PigScriptParser.parse(PigScriptParser.java:412)
    at org.apache.pig.tools.grunt.GruntParser.parseStopOnError(GruntParser.java:194)
    at org.apache.pig.tools.grunt.GruntParser.parseStopOnError(GruntParser.java:170)
    at org.apache.pig.tools.grunt.Grunt.run(Grunt.java:69)
    at org.apache.pig.Main.run(Main.java:538)
    at org.apache.pig.Main.main(Main.java:157)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.hadoop.util.RunJar.main(RunJar.java:156)
================================================================================

的内容sample_data.csv是:

1, John, Smith
2, Jane, Doe
3, George, Washington
4, Ben, Franklin

我还将$PIG_HOME变量设置为 pig 目录的主文件夹。

我也知道之前提出的类似问题。这里

但是,即使我$PIG_CLASSPATH按照说明设置变量,并echo编辑$PIG_CLASSPATH以确保它设置正确,我仍然会遇到相同的错误。

4

1 回答 1

1

在挠了我的头 24 小时后。在同事的帮助下,我终于弄明白了。

那是因为Hive. 出于某种原因,当两者PigHive都设置在同一台机器上时,这往往会发生。所以我需要做的就是

export HIVE_HOME=
于 2013-06-19T14:46:38.253 回答