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