鍍金池/ 教程/ 大數(shù)據(jù)/ HBase創(chuàng)建表
HBase禁用表
HBase創(chuàng)建表
HBase客戶端API
HBase安裝
HBase表描述和修改
HBase Admin API
HBase掃描
HBase創(chuàng)建數(shù)據(jù)
HBase列出表
HBase刪除數(shù)據(jù)
HBase讀取數(shù)據(jù)
HBase常用命令
HBase更新數(shù)據(jù)
HBase關(guān)閉
HBase架構(gòu)
HBase Shell
HBase Exists
HBase安全
HBase教程
HBase啟用表
HBase計數(shù)和截斷
HBase刪除表

HBase創(chuàng)建表

可以使用命令創(chuàng)建一個表,在這里必須指定表名和列族名。在HBase shell中創(chuàng)建表的語法如下所示。

create ‘<table name>’,’<column family>’ 

示例

下面給出的是一個表名為emp的樣本模式。它有兩個列族:“personal data”和“professional data”。

Row key personal data professional data
     
     

在HBase shell創(chuàng)建該表如下所示。

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

它會給下面的輸出。

0 row(s) in 1.1300 seconds


=> Hbase::Table - emp

驗證創(chuàng)建

可以驗證是否已經(jīng)創(chuàng)建,使用 list 命令如下所示。在這里,可以看到創(chuàng)建的emp表。

hbase(main):002:0> list


TABLE 

emp
2 row(s) in 0.0340 seconds

使用Java API創(chuàng)建一個表

可以使用HBaseAdmin類的createTable()方法創(chuàng)建表在HBase中。這個類屬于org.apache.hadoop.hbase.client 包。下面給出的步驟是來使用Java API創(chuàng)建表在HBase中。

第1步:實例化HBaseAdmin

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

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

第2步:創(chuàng)建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步:通過執(zhí)行管理

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

admin.createTable(table);

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

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 ");
   }
  上一篇:HBase刪除數(shù)據(jù)下一篇:HBase Shell