HBase - Créer des données

Insertion de données à l'aide de HBase Shell

Ce chapitre montre comment créer des données dans une table HBase. Pour créer des données dans une table HBase, les commandes et méthodes suivantes sont utilisées:

  • put commander,

  • add() méthode de Put classe, et

  • put() méthode de HTable classe.

A titre d'exemple, nous allons créer le tableau suivant dans HBase.

En utilisant putcommande, vous pouvez insérer des lignes dans une table. Sa syntaxe est la suivante:

put ’<table name>’,’row1’,’<colfamily:colname>’,’<value>’

Insertion de la première ligne

Insérons les valeurs de la première ligne dans le tableau emp comme indiqué ci-dessous.

hbase(main):005:0> put 'emp','1','personal data:name','raju'
0 row(s) in 0.6600 seconds
hbase(main):006:0> put 'emp','1','personal data:city','hyderabad'
0 row(s) in 0.0410 seconds
hbase(main):007:0> put 'emp','1','professional
data:designation','manager'
0 row(s) in 0.0240 seconds
hbase(main):007:0> put 'emp','1','professional data:salary','50000'
0 row(s) in 0.0240 seconds

Insérez les lignes restantes en utilisant la commande put de la même manière. Si vous insérez la table entière, vous obtiendrez la sortie suivante.

hbase(main):022:0> scan 'emp'

   ROW                        COLUMN+CELL
1 column=personal data:city, timestamp=1417524216501, value=hyderabad

1 column=personal data:name, timestamp=1417524185058, value=ramu

1 column=professional data:designation, timestamp=1417524232601,

 value=manager
 
1 column=professional data:salary, timestamp=1417524244109, value=50000

2 column=personal data:city, timestamp=1417524574905, value=chennai

2 column=personal data:name, timestamp=1417524556125, value=ravi

2 column=professional data:designation, timestamp=1417524592204,

 value=sr:engg
 
2 column=professional data:salary, timestamp=1417524604221, value=30000

3 column=personal data:city, timestamp=1417524681780, value=delhi

3 column=personal data:name, timestamp=1417524672067, value=rajesh

3 column=professional data:designation, timestamp=1417524693187,

value=jr:engg
3 column=professional data:salary, timestamp=1417524702514,

value=25000

Insertion de données à l'aide de l'API Java

Vous pouvez insérer des données dans Hbase à l'aide du add() méthode de la Putclasse. Vous pouvez l'enregistrer en utilisant leput() méthode de la HTableclasse. Ces classes appartiennent auorg.apache.hadoop.hbase.clientpaquet. Vous trouverez ci-dessous les étapes pour créer des données dans un tableau de HBase.

Étape 1: instancier la classe de configuration

le ConfigurationLa classe ajoute des fichiers de configuration HBase à son objet. Vous pouvez créer un objet de configuration à l'aide ducreate() méthode de la HbaseConfiguration classe comme indiqué ci-dessous.

Configuration conf = HbaseConfiguration.create();

Étape 2: instancier la classe HTable

Vous avez une classe appelée HTable, une implémentation de Table dans HBase. Cette classe est utilisée pour communiquer avec une seule table HBase. Lors de l'instanciation de cette classe, elle accepte l'objet de configuration et le nom de la table comme paramètres. Vous pouvez instancier la classe HTable comme indiqué ci-dessous.

HTable hTable = new HTable(conf, tableName);

Étape 3: instancier la PutClass

Pour insérer des données dans une table HBase, le add()méthode et ses variantes sont utilisées. Cette méthode appartient àPut, instanciez donc la classe put. Cette classe nécessite le nom de ligne dans lequel vous souhaitez insérer les données, au format chaîne. Vous pouvez instancier lePut classe comme indiqué ci-dessous.

Put p = new Put(Bytes.toBytes("row1"));

Étape 4: insérer des données

le add() méthode de Putclass est utilisé pour insérer des données. Il nécessite des tableaux de 3 octets représentant la famille de colonnes, le qualificateur de colonne (nom de la colonne) et la valeur à insérer, respectivement. Insérez des données dans la table HBase en utilisant la méthode add () comme indiqué ci-dessous.

p.add(Bytes.toBytes("coloumn family "), Bytes.toBytes("column
name"),Bytes.toBytes("value"));

Étape 5: enregistrer les données dans le tableau

Après avoir inséré les lignes requises, enregistrez les modifications en ajoutant l'instance put au put() méthode de la classe HTable comme indiqué ci-dessous.

hTable.put(p);

Étape 6: fermez l'instance HTable

Après avoir créé des données dans la table HBase, fermez le HTable instance utilisant le close() méthode comme indiqué ci-dessous.

hTable.close();

Ci-dessous est le programme complet pour créer des données dans le tableau HBase.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.util.Bytes;

public class InsertData{

   public static void main(String[] args) throws IOException {

      // Instantiating Configuration class
      Configuration config = HBaseConfiguration.create();

      // Instantiating HTable class
      HTable hTable = new HTable(config, "emp");

      // Instantiating Put class
      // accepts a row name.
      Put p = new Put(Bytes.toBytes("row1")); 

      // adding values using add() method
      // accepts column family name, qualifier/row name ,value
      p.add(Bytes.toBytes("personal"),
      Bytes.toBytes("name"),Bytes.toBytes("raju"));

      p.add(Bytes.toBytes("personal"),
      Bytes.toBytes("city"),Bytes.toBytes("hyderabad"));

      p.add(Bytes.toBytes("professional"),Bytes.toBytes("designation"),
      Bytes.toBytes("manager"));

      p.add(Bytes.toBytes("professional"),Bytes.toBytes("salary"),
      Bytes.toBytes("50000"));
      
      // Saving the put Instance to the HTable.
      hTable.put(p);
      System.out.println("data inserted");
      
      // closing HTable
      hTable.close();
   }
}

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

$javac InsertData.java
$java InsertData

Ce qui suit devrait être la sortie:

data inserted