HBase创建表 HBase管理API HBase清单表 使用HBase Shell创建表 您可以使用 create 命令创建一个表格,在这里您必须指定表格名称和列名称。下面显示了在HBase shell中创建表的 语法 。 create ‘<table name>’,’<column family>’ 例 下面给出了一个名为emp的表的示例模式。它有两个专栏系列:“个人资料”和“专业资料”。 行键 个人资料 专业数据 您可以在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中创建表的步骤。 第一步:实例化HBaseAdmin 该类需要Configuration对象作为参数,因此最初实例化Configuration类并将此实例传递给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 HTableDescriptor(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 HBase管理API HBase清单表