HBase - Mettre à jour les données

Mise à jour des données à l'aide de HBase Shell

Vous pouvez mettre à jour une valeur de cellule existante à l'aide du putcommander. Pour ce faire, suivez simplement la même syntaxe et mentionnez votre nouvelle valeur comme indiqué ci-dessous.

put ‘table name’,’row ’,'Column family:column name',’new value’

La valeur nouvellement donnée remplace la valeur existante, mettant à jour la ligne.

Exemple

Supposons qu'il existe une table dans HBase appelée emp avec les données suivantes.

hbase(main):003:0> scan 'emp'
 ROW              COLUMN + CELL
row1 column = personal:name, timestamp = 1418051555, value = raju
row1 column = personal:city, timestamp = 1418275907, value = Hyderabad
row1 column = professional:designation, timestamp = 14180555,value = manager
row1 column = professional:salary, timestamp = 1418035791555,value = 50000
1 row(s) in 0.0100 seconds

La commande suivante mettra à jour la valeur de la ville de l'employé nommé «Raju» à Delhi.

hbase(main):002:0> put 'emp','row1','personal:city','Delhi'
0 row(s) in 0.0400 seconds

Le tableau mis à jour se présente comme suit où vous pouvez observer que la ville de Raju a été changée en «Delhi».

hbase(main):003:0> scan 'emp'
  ROW          COLUMN + CELL
row1 column = personal:name, timestamp = 1418035791555, value = raju
row1 column = personal:city, timestamp = 1418274645907, value = Delhi
row1 column = professional:designation, timestamp = 141857555,value = manager
row1 column = professional:salary, timestamp = 1418039555, value = 50000
1 row(s) in 0.0100 seconds

Mise à jour des données à l'aide de l'API Java

Vous pouvez mettre à jour les données dans une cellule particulière en utilisant le put()méthode. Suivez les étapes ci-dessous pour mettre à jour une valeur de cellule existante d'un tableau.

Étape 1: instancier la classe de configuration

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 classe Put

Pour insérer des données dans la table HBase, le add()méthode et ses variantes sont utilisées. Cette méthode appartient àPut, instanciez donc le putclasse. 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: mettre à jour une cellule existante

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 le tableau HBase à l'aide duadd() méthode comme indiqué ci-dessous.

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

É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: Fermer l'instance HTable

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

hTable.close();

Ci-dessous est le programme complet pour mettre à jour les données dans un tableau particulier.

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 UpdateData{

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

      // Updating a cell value
      p.add(Bytes.toBytes("personal"),
      Bytes.toBytes("city"),Bytes.toBytes("Delih"));

      // Saving the put Instance to the HTable.
      hTable.put(p);
      System.out.println("data Updated");

      // closing HTable
      hTable.close();
   }
}

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

$javac UpdateData.java
$java UpdateData

Ce qui suit devrait être la sortie:

data Updated