Hbase命令創建表和Java API

HBase創建表

create 'table name(表名)','column family(列族名)'

例子:

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

輸出信息:

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

驗證表是否創建成功,使用list命令列出所有的表:

hbase(main):002:0> list
TABLE 
member
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 
   HBaseAdmin admin = new HBaseAdmin(con);

   // Instantiating table descriptor class  設置表名
   HTableDescriptor tableDescriptor = new
   TableDescriptor(TableName.valueOf("member"));

   // 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 ");
   }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章