HBase - Supprimer les données

Suppression d'une cellule spécifique dans un tableau

En utilisant le deletecommande, vous pouvez supprimer une cellule spécifique dans un tableau. La syntaxe dedelete La commande est la suivante:

delete ‘<table name>’, ‘<row>’, ‘<column name >’, ‘<time stamp>’

Exemple

Voici un exemple pour supprimer une cellule spécifique. Ici, nous supprimons le salaire.

hbase(main):006:0> delete 'emp', '1', 'personal data:city',
1417521848375
0 row(s) in 0.0060 seconds

Suppression de toutes les cellules d'un tableau

À l'aide de la commande «deleteall», vous pouvez supprimer toutes les cellules d'une ligne. Vous trouverez ci-dessous la syntaxe de la commande deleteall.

deleteall ‘<table name>’, ‘<row>’,

Exemple

Voici un exemple de commande «deleteall», où nous supprimons toutes les cellules de la ligne 1 de la table emp.

hbase(main):007:0> deleteall 'emp','1'
0 row(s) in 0.0240 seconds

Vérifiez le tableau à l'aide du scancommander. Un aperçu du tableau après la suppression du tableau est donné ci-dessous.

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

ROW                  COLUMN + CELL

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

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

2 column = professional data:designation, timestamp = 1417524204, 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 = 1417523187, value = jr:engg

3 column = professional data:salary, timestamp = 1417524702514, value = 25000

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

Vous pouvez supprimer des données d'une table HBase à l'aide du delete() méthode de la HTableclasse. Suivez les étapes ci-dessous pour supprimer des données 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 de suppression

Instancier le Deleteclass en passant l'ID de ligne de la ligne à supprimer, au format tableau d'octets. Vous pouvez également transmettre l'horodatage et Rowlock à ce constructeur.

Delete delete = new Delete(toBytes("row1"));

Étape 4: Sélectionnez les données à supprimer

Vous pouvez supprimer les données à l'aide des méthodes de suppression du Deleteclasse. Cette classe a différentes méthodes de suppression. Choisissez les colonnes ou familles de colonnes à supprimer à l'aide de ces méthodes. Jetez un œil aux exemples suivants qui montrent l'utilisation des méthodes de classe Delete.

delete.deleteColumn(Bytes.toBytes("personal"), Bytes.toBytes("name"));
delete.deleteFamily(Bytes.toBytes("professional"));

Étape 5: supprimer les données

Supprimez les données sélectionnées en passant le delete instance à la delete() méthode de la HTable classe comme indiqué ci-dessous.

table.delete(delete);

Étape 6: fermez HTableInstance

Après avoir supprimé les données, fermez le HTable Exemple.

table.close();

Vous trouverez ci-dessous le programme complet pour supprimer des données de la table HBase.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

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

public class DeleteData {

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

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

      // Instantiating HTable class
      HTable table = new HTable(conf, "employee");

      // Instantiating Delete class
      Delete delete = new Delete(Bytes.toBytes("row1"));
      delete.deleteColumn(Bytes.toBytes("personal"), Bytes.toBytes("name"));
      delete.deleteFamily(Bytes.toBytes("professional"));

      // deleting the data
      table.delete(delete);

      // closing the HTable object
      table.close();
      System.out.println("data deleted.....");
   }
}

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

$javac Deletedata.java
$java DeleteData

Ce qui suit devrait être la sortie:

data deleted