HBase - Créer des données
Insertion de données à l'aide de HBase Shell
Ce chapitre montre comment créer des données dans une table HBase. Pour créer des données dans une table HBase, les commandes et méthodes suivantes sont utilisées:
put commander,
add() méthode de Put classe, et
put() méthode de HTable classe.
A titre d'exemple, nous allons créer le tableau suivant dans HBase.
En utilisant putcommande, vous pouvez insérer des lignes dans une table. Sa syntaxe est la suivante:
put ’<table name>’,’row1’,’<colfamily:colname>’,’<value>’
Insertion de la première ligne
Insérons les valeurs de la première ligne dans le tableau emp comme indiqué ci-dessous.
hbase(main):005:0> put 'emp','1','personal data:name','raju'
0 row(s) in 0.6600 seconds
hbase(main):006:0> put 'emp','1','personal data:city','hyderabad'
0 row(s) in 0.0410 seconds
hbase(main):007:0> put 'emp','1','professional
data:designation','manager'
0 row(s) in 0.0240 seconds
hbase(main):007:0> put 'emp','1','professional data:salary','50000'
0 row(s) in 0.0240 seconds
Insérez les lignes restantes en utilisant la commande put de la même manière. Si vous insérez la table entière, vous obtiendrez la sortie suivante.
hbase(main):022:0> scan 'emp'
ROW COLUMN+CELL
1 column=personal data:city, timestamp=1417524216501, value=hyderabad
1 column=personal data:name, timestamp=1417524185058, value=ramu
1 column=professional data:designation, timestamp=1417524232601,
value=manager
1 column=professional data:salary, timestamp=1417524244109, value=50000
2 column=personal data:city, timestamp=1417524574905, value=chennai
2 column=personal data:name, timestamp=1417524556125, value=ravi
2 column=professional data:designation, timestamp=1417524592204,
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=1417524693187,
value=jr:engg
3 column=professional data:salary, timestamp=1417524702514,
value=25000
Insertion de données à l'aide de l'API Java
Vous pouvez insérer des données dans Hbase à l'aide du add() méthode de la Putclasse. Vous pouvez l'enregistrer en utilisant leput() méthode de la HTableclasse. Ces classes appartiennent auorg.apache.hadoop.hbase.clientpaquet. Vous trouverez ci-dessous les étapes pour créer des données dans un tableau de HBase.
Étape 1: instancier la classe de configuration
le 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 PutClass
Pour insérer des données dans une table HBase, le add()méthode et ses variantes sont utilisées. Cette méthode appartient àPut, instanciez donc la classe put. 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: insérer des données
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 la table HBase en utilisant la méthode add () comme indiqué ci-dessous.
p.add(Bytes.toBytes("coloumn family "), Bytes.toBytes("column
name"),Bytes.toBytes("value"));
É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: fermez l'instance HTable
Après avoir créé des données dans la table HBase, fermez le HTable instance utilisant le close() méthode comme indiqué ci-dessous.
hTable.close();
Ci-dessous est le programme complet pour créer des données dans le tableau HBase.
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 InsertData{
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"));
// adding values using add() method
// accepts column family name, qualifier/row name ,value
p.add(Bytes.toBytes("personal"),
Bytes.toBytes("name"),Bytes.toBytes("raju"));
p.add(Bytes.toBytes("personal"),
Bytes.toBytes("city"),Bytes.toBytes("hyderabad"));
p.add(Bytes.toBytes("professional"),Bytes.toBytes("designation"),
Bytes.toBytes("manager"));
p.add(Bytes.toBytes("professional"),Bytes.toBytes("salary"),
Bytes.toBytes("50000"));
// Saving the put Instance to the HTable.
hTable.put(p);
System.out.println("data inserted");
// closing HTable
hTable.close();
}
}
Compilez et exécutez le programme ci-dessus comme indiqué ci-dessous.
$javac InsertData.java
$java InsertData
Ce qui suit devrait être la sortie:
data inserted