当前位置:   article > 正文

hive创建hbase外部关联表实例

hive创建hbase外部关联表实例

在cdh6.3.2已经做好hbase和hive相关配置,这里不阐述。

要创建上述的表结构,你需要先在HBase中创建相应的表,然后在Hive中创建一个EXTERNAL TABLE来映射到这个HBase表。以下是详细的步骤:

步骤1:在HBase中创建表

  1. 确定HBase的安装和配置是否正确。
  2. 确定HBase的shell工具能够正常使用。

打开HBase shell

hbase shell

在HBase shell中,创建一个表analysis_minute和一个列族bls

create 'analysis_minute', 'bls'

退出HBase shell:

quit

步骤2:在Hive中创建EXTERNAL TABLE

  1. 确保Hive安装和配置正确。
  2. 确保HBaseStorageHandler已经包含在Hive的配置中。

使用Hive的命令行界面或者你的IDE来执行下面的SQL语句:

  1. CREATE EXTERNAL TABLE analysis_minute_hbase (
  2. key STRING,
  3. pid STRING,
  4. time STRING,
  5. val STRING
  6. )
  7. STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'
  8. WITH SERDEPROPERTIES (
  9. 'hbase.columns.mapping' = ':key,bls:pid,bls:time,bls:val',
  10. 'serialization.format' = '1'
  11. )
  12. TBLPROPERTIES (
  13. 'hbase.table.name' = 'analysis_minute',
  14. 'last_modified_by' = 'hdfs',
  15. 'last_modified_time' = '1713990161',
  16. 'numFiles' = '0',
  17. 'numFilesErasureCoded' = '0',
  18. 'numRows' = '0',
  19. 'rawDataSize' = '0',
  20. 'storage_handler' = 'org.apache.hadoop.hive.hbase.HBaseStorageHandler',
  21. 'totalSize' = '0'
  22. );

这段SQL语句做了以下几件事情:

  • 创建了一个EXTERNAL TABLE,意味着数据存储在HBase中,而不是Hive的数据仓库目录中。
  • 使用了HBaseStorageHandler来允许Hive与HBase交互。
  • 定义了四个字段,分别对应于HBase表中的列。
  • 通过WITH SERDEPROPERTIES定义了Hive字段到HBase列族的映射。
  • 通过TBLPROPERTIES定义了HBase表的名称和其他属性。

注意事项:

  • 确保HBase表analysis_minute和列族bls已经存在,Hive才能正确创建EXTERNAL TABLE。
  • 确认Hive配置文件中已经包含了HBaseStorageHandler的jar包。
  • 如果HBase表或列族名称与Hive表结构中的名称不匹配,Hive将无法找到对应的HBase表。
  • 在执行上述Hive SQL语句之前,你可能需要根据你的Hadoop和Hive版本调整配置参数。
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/522203
推荐阅读
相关标签
  

闽ICP备14008679号