HBase - Créer une table

Création d'une table à l'aide de HBase Shell

Vous pouvez créer une table à l'aide du createcommande, ici vous devez spécifier le nom de la table et le nom de la famille de colonnes. lesyntax pour créer une table dans le shell HBase est illustré ci-dessous.

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

Exemple

Vous trouverez ci-dessous un exemple de schéma d'une table nommée emp. Il comporte deux familles de colonnes: «données personnelles» et «données professionnelles».

Touche de ligne données personnelles données professionnelles

Vous pouvez créer cette table dans le shell HBase comme indiqué ci-dessous.

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

Et cela vous donnera la sortie suivante.

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

Vérification

Vous pouvez vérifier si la table est créée à l'aide du listcomme indiqué ci-dessous. Ici vous pouvez observer la table emp créée.

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

Créer une table à l'aide de l'API Java

Vous pouvez créer une table dans HBase en utilisant le createTable() méthode de HBaseAdminclasse. Cette classe appartient à laorg.apache.hadoop.hbase.clientpaquet. Vous trouverez ci-dessous les étapes pour créer une table dans HBase à l'aide de l'API java.

Étape 1: instancier HBaseAdmin

Cette classe requiert l'objet Configuration en tant que paramètre, instanciez donc initialement la classe Configuration et transmettez cette instance à HBaseAdmin.

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

Étape 2: créer un descripteur de table

HTableDescriptor est une classe qui appartient au org.apache.hadoop.hbaseclasse. Cette classe est comme un conteneur de noms de table et de familles de colonnes.

//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);

Étape 3: Exécuter via l'administrateur

En utilisant le createTable() méthode de HBaseAdmin class, vous pouvez exécuter la table créée en mode Admin.

admin.createTable(table);

Vous trouverez ci-dessous le programme complet pour créer une table via 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 {

      // 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 ");
   }
}

Compilez et exécutez le programme ci-dessus comme indiqué ci-dessous.

$javac CreateTable.java
$java CreateTable

Ce qui suit devrait être la sortie:

Table created