Hive 集成 Hbase
1. 使用 HQL 语句创建一个指向 HBase 的 Hive 表
-- 尝试以下,所以全部为string类型CREATE TABLE hbase_table(key string,name string,gender string,age string)-- 指定存储处理器STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'-- 声明HBase中对应的表的列簇及列名WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key,base:name,base:gender,base:age")-- hbase.table.name声明HBase表名,为可选属性,默认与Hive中的表名相同-- hbase.mapred.output.outputtable指定插入数据时写入的表,如果以后需要往该表插入数TBLPROPERTIES ("hbase.table.name" = "mystudent", "hbase.mapred.output.outputtable" = "mystudent");
2. 使用 Hive 中创建一个指向已经存在的 HBase 表的 Hive 表
-- 由于数据存储在Hbase中,所以是external表,并指定在创建的Hive表名CREATE EXTERNAL TABLE hbase_table_2(key string, name string,gender string ,age string)-- 指定存储处理器STORED BY 'org.apache.hadoop.hive.hbase.HBaseStorageHandler'-- Hive和HBase之间的映射关系WITH SERDEPROPERTIES ("hbase.columns.mapping" = ":key ,base:name,base:gender,base:age")-- 指定已存在的Hbase表TBLPROPERTIES("hbase.table.name" = "student", "hbase.mapred.output.outputtable" = "student");