2017-01-03 8 views
0

Hiveを使用してHBaseテーブルを作成しようとしています(これは、別のHiveテーブルから挿入することを目的としています)。HBaseテーブル???テーブルが外部テーブルとして宣言されている間は存在しません

CREATE EXTERNAL TABLE HBWeather (key struct<USAF:INT, WBAN:INT, `Date`:STRING>, TEMP INT) 
ROW FORMAT DELIMITED 
COLLECTION ITEMS TERMINATED BY '~' 
STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler' 
WITH SERDEPROPERTIES ('hbase.columns.mapping'=':key,T:Temp'); 

しかし、私は次のエラーを取得しています:

FAILED: Execution Error, return code 1 from org.apache.hadoop.hive.ql.exec.DDLTask. MetaException(message:MetaException(message:HBase table hbweather doesn't exist while the table is declared as an external table.) 
    at org.apache.hadoop.hive.hbase.HBaseStorageHandler.preCreateTable(HBaseStorageHandler.java:225) 
    at org.apache.hadoop.hive.metastore.HiveMetaStoreClient.createTable(HiveMetaStoreClient.java:731) 
    at org.apache.hadoop.hive.metastore.HiveMetaStoreClient.createTable(HiveMetaStoreClient.java:724) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at org.apache.hadoop.hive.metastore.RetryingMetaStoreClient.invoke(RetryingMetaStoreClient.java:154) 
    at com.sun.proxy.$Proxy23.createTable(Unknown Source) 
    at org.apache.hadoop.hive.ql.metadata.Hive.createTable(Hive.java:830) 
    at org.apache.hadoop.hive.ql.metadata.Hive.createTable(Hive.java:845) 
    at org.apache.hadoop.hive.ql.exec.DDLTask.createTable(DDLTask.java:3979) 
    at org.apache.hadoop.hive.ql.exec.DDLTask.execute(DDLTask.java:333) 
    at org.apache.hadoop.hive.ql.exec.Task.executeTask(Task.java:197) 
    at org.apache.hadoop.hive.ql.exec.TaskRunner.runSequential(TaskRunner.java:100) 
    at org.apache.hadoop.hive.ql.Driver.launchTask(Driver.java:1858) 
    at org.apache.hadoop.hive.ql.Driver.execute(Driver.java:1562) 
    at org.apache.hadoop.hive.ql.Driver.runInternal(Driver.java:1313) 
    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:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:606) 
    at org.apache.hadoop.util.RunJar.run(RunJar.java:221) 
    at org.apache.hadoop.util.RunJar.main(RunJar.java:136) 
) 

は正確に問題は何ですか?それを修正する方法は?事前に

おかげで

答えて

0

外部表を作成するには、コマンドの「場所」コンポーネントが不足しています。 「外部」を指定したので、Hiveがテーブルを作成するHDFS上にファイルシステムパスを指定する必要があります。それは1行目で報告されたエラーです。

関連する問題