HBase - Lire les données

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

le get commande et le get() méthode de HTableclass sont utilisés pour lire les données d'une table dans HBase. En utilisantgetcommande, vous pouvez obtenir une seule ligne de données à la fois. Sa syntaxe est la suivante:

get ’<table name>’,’row1’

Exemple

L'exemple suivant montre comment utiliser la commande get. Passons en revue la première ligne duemp table.

hbase(main):012:0> get 'emp', '1'

   COLUMN                     CELL
   
personal : city timestamp = 1417521848375, value = hyderabad

personal : name timestamp = 1417521785385, value = ramu

professional: designation timestamp = 1417521885277, value = manager

professional: salary timestamp = 1417521903862, value = 50000

4 row(s) in 0.0270 seconds

Lire une colonne spécifique

Vous trouverez ci-dessous la syntaxe pour lire une colonne spécifique en utilisant le get méthode.

hbase> get 'table name', ‘rowid’, {COLUMN ⇒ ‘column family:column name ’}

Exemple

Ci-dessous, l'exemple de lecture d'une colonne spécifique dans le tableau HBase.

hbase(main):015:0> get 'emp', 'row1', {COLUMN ⇒ 'personal:name'}
  COLUMN                CELL  
personal:name timestamp = 1418035791555, value = raju
1 row(s) in 0.0080 seconds

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

Pour lire les données d'une table HBase, utilisez le get()méthode de la classe HTable. Cette méthode nécessite une instance duGetclasse. Suivez les étapes ci-dessous pour récupérer les données de la table HBase.

É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 Get

Vous pouvez récupérer des données de la table HBase à l'aide du get() méthode de la HTableclasse. Cette méthode extrait une cellule d'une ligne donnée. Cela nécessite unGetobjet de classe comme paramètre. Créez-le comme indiqué ci-dessous.

Get get = new Get(toBytes("row1"));

Étape 4: lire les données

Lors de la récupération des données, vous pouvez obtenir une seule ligne par ID, ou obtenir un ensemble de lignes par un ensemble d'ID de ligne, ou analyser une table entière ou un sous-ensemble de lignes.

Vous pouvez récupérer les données d'une table HBase à l'aide des variantes de méthode d'ajout dans Get classe.

Pour obtenir une colonne spécifique à partir d'une famille de colonnes spécifique, utilisez la méthode suivante.

get.addFamily(personal)

Pour obtenir toutes les colonnes d'une famille de colonnes spécifique, utilisez la méthode suivante.

get.addColumn(personal, name)

Étape 5: Obtenez le résultat

Obtenez le résultat en passant votre Get classe à la méthode get du HTableclasse. Cette méthode renvoie leResultobjet de classe, qui contient le résultat demandé. Ci-dessous, l'utilisation deget() méthode.

Result result = table.get(g);

Étape 6: lecture des valeurs de l'instance de résultat

le Result classe fournit le getValue()pour lire les valeurs de son instance. Utilisez-le comme indiqué ci-dessous pour lire les valeurs duResult exemple.

byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));
byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));

Vous trouverez ci-dessous le programme complet pour lire les valeurs d'une table HBase.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

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

public class RetriveData{

   public static void main(String[] args) throws IOException, Exception{
   
      // Instantiating Configuration class
      Configuration config = HBaseConfiguration.create();

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

      // Instantiating Get class
      Get g = new Get(Bytes.toBytes("row1"));

      // Reading the data
      Result result = table.get(g);

      // Reading values from Result class object
      byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));

      byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));

      // Printing the values
      String name = Bytes.toString(value);
      String city = Bytes.toString(value1);
      
      System.out.println("name: " + name + " city: " + city);
   }
}

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

$javac RetriveData.java
$java RetriveData

Ce qui suit devrait être la sortie:

name: Raju city: Delhi