HBase - 创建表

使用 HBase Shell 创建表

您可以使用 create 命令创建表,在这里您必须指定表名和列系列名称。在 HBase shell 中创建表的语法如下所示。

create '<table name>','<column family>'

示例

下面给出了名为 emp 的表的示例架构。它有两个列系列:"personal data(个人数据)"和"professional data(专业数据)"。

Row key personal data professional data

您可以在 HBase shell 中创建此表,如下所示。

hbase(main):002:0> create 'emp', 'personal data', 'professional data'

它将为您提供以下输出。

0 row(s) in 1.1300 seconds
=> Hbase::Table - emp

验证

您可以使用 list 命令验证表是否已创建,如下所示。在这里您可以观察创建的 emp 表。

hbase(main):002:0> list
TABLE 
emp
2 row(s) in 0.0340 seconds

使用 Java API 创建表

您可以使用 HBaseAdmin 类的 createTable() 方法在 HBase 中创建表。此类属于 org.apache.hadoop.hbase.client 包。下面给出了使用 Java API 在 HBase 中创建表的步骤。

步骤 1:实例化 HBaseAdmin

此类需要 Configuration 对象作为参数,因此首先实例化 Configuration 类并将此实例传递给 HBaseAdmin。

Configuration conf = HBaseConfiguration.create();
HBaseAdmin admin = new HBaseAdmin(conf);

步骤2:创建TableDescriptor

HTableDescriptor是属于org.apache.hadoop.hbase类的一个类。该类就像是表名和列族的容器。

//创建表描述符
HTableDescriptor table = new HTableDescriptor(toBytes("表名"));

//创建列族描述符
HColumnDescriptor family = new HColumnDescriptor(toBytes("列族"));

//将列族添加到HTable
table.addFamily(family);

步骤3:通过Admin执行

使用HBaseAdmin类的createTable()方法,可以在Admin模式下执行创建的表。

admin.createTable(table);

下面给出了通过admin创建表的完整程序。

import java.io.IOException;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.TableName;

import org.apache.hadoop.conf.Configuration;

public class CreateTable {
      
   public static void main(String[] args) throws IOException {

        // 实例化配置类
        Configuration con = HBaseConfiguration.create();
        
        // 实例化 HbaseAdmin 类
        HBaseAdmin admin = new HBaseAdmin(con);
        
        // 实例化表描述符类
        HTableDescriptor tableDescriptor = new
        HTableDescriptor(TableName.valueOf("emp"));
        
        // 向表描述符添加列族
        tableDescriptor.addFamily(new HColumnDescriptor("personal"));
        tableDescriptor.addFamily(new HColumnDescriptor("professional"));
        
        // 通过 admin 执行表
        admin.createTable(tableDescriptor);
        System.out.println(" 表已创建 ");
   }
}

编译并执行上述程序,如下所示。

$javac CreateTable.java
$java CreateTable

输出应如下所示:

Table created