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