2016-11-07 61 views
0

我試圖運行「dbms_output.put_line('This is HPL/Sql');」來自Hive cli它給出了以下例外。無法運行HIVE cli的HPL/SQL查詢

NoViableAltException([email protected][]) 
    at org.apache.hadoop.hive.ql.parse.HiveParser.statement(HiveParser.java:1140) 
    at org.apache.hadoop.hive.ql.parse.ParseDriver.parse(ParseDriver.java:204) 
    at org.apache.hadoop.hive.ql.parse.ParseDriver.parse(ParseDriver.java:166) 
    at org.apache.hadoop.hive.ql.Driver.compile(Driver.java:404) 
    at org.apache.hadoop.hive.ql.Driver.compile(Driver.java:329) 
    at org.apache.hadoop.hive.ql.Driver.compileInternal(Driver.java:1158) 
    at org.apache.hadoop.hive.ql.Driver.runInternal(Driver.java:1253) 
    at org.apache.hadoop.hive.ql.Driver.run(Driver.java:1084) 
    at org.apache.hadoop.hive.ql.Driver.run(Driver.java:1072) 
    at org.apache.hadoop.hive.cli.CliDriver.processLocalCmd(CliDriver.java:232) 
    at org.apache.hadoop.hive.cli.CliDriver.processCmd(CliDriver.java:183) 
    at org.apache.hadoop.hive.cli.CliDriver.processLine(CliDriver.java:399) 
    at org.apache.hadoop.hive.cli.CliDriver.executeDriver(CliDriver.java:776) 
    at org.apache.hadoop.hive.cli.CliDriver.run(CliDriver.java:714) 
    at org.apache.hadoop.hive.cli.CliDriver.main(CliDriver.java:641) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:498) 
    at org.apache.hadoop.util.RunJar.run(RunJar.java:221) 
    at org.apache.hadoop.util.RunJar.main(RunJar.java:136) 

FAILED: '0不能夠識別鄰近 'DBMS_OUTPUT'' 輸入: ParseException的線1。 'put_line'

我正在使用Hive 2.1.0。 按照HPL/sql文檔HPL/SQL自2.0版以來已包含在Apache Hive中。

是否需要進行任何其他配置更改才能在配置單元中啓用hpl/sql支持。

回答

1

我們無法直接從Hive Cli運行HPL/SQL查詢。我們應該使用 1. hplsql -e'query'或者2. hplsql -e sql/hql文件。在HPL/SQL

對於例 -

hplsql -e 'dbms_output.put_line(`this is hplsql`)'; 
or 
hplsql -e 'PRINT `this is hplsql`'; 
0

寫入功能,其註冊在蜂巢和使用它。

+0

雖然這可能回答這個問題,但考慮簡要地向OP解釋它 –