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