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