HBase創建表

可以使用命令創建一個表,在這裏必須指定表名和列族名。在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

這個類需要配置對象作爲參數,因此初始實例配置類傳遞此實例給HBaseAdmin。

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

第2步:創建TableDescriptor

HTableDescriptor類是屬於org.apache.hadoop.hbase。這個類就像表名和列族的容器一樣。

//creating table descriptor HTableDescriptor table = new HTableDescriptor(toBytes("Table name")); //creating column family descriptor HColumnDescriptor family = new HColumnDescriptor(toBytes("column family")); //adding coloumn family to HTable table.addFamily(family);

第3步:通過執行管理

使用HBaseAdmin類的createTable()方法,可以在管理模式執行創建的表。

admin.createTable(table);

下面給出的是完整的程序,通過管理員創建一個表。

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 { // Instantiating configuration class Configuration con = HBaseConfiguration.create(); // Instantiating HbaseAdmin class HBaseAdmin admin = new HBaseAdmin(con); // Instantiating table descriptor class HTableDescriptor tableDescriptor = new TableDescriptor(TableName.valueOf("emp")); // Adding column families to table descriptor tableDescriptor.addFamily(new HColumnDescriptor("personal")); tableDescriptor.addFamily(new HColumnDescriptor("professional")); // Execute the table through admin admin.createTable(tableDescriptor); System.out.println(" Table created "); } }

編譯和執行上述程序如下所示。

$javac CreateTable.java
$java CreateTable

下面列出的是輸出:

Table created