HBase - Utwórz dane

Wstawianie danych przy użyciu powłoki HBase

W tym rozdziale pokazano, jak tworzyć dane w tabeli HBase. Aby utworzyć dane w tabeli HBase, używane są następujące polecenia i metody:

  • put Komenda,

  • add() metoda Put klasa i

  • put() metoda HTable klasa.

Jako przykład utworzymy następującą tabelę w HBase.

Za pomocą putpolecenie, możesz wstawiać wiersze do tabeli. Jego składnia jest następująca:

put ’<table name>’,’row1’,’<colfamily:colname>’,’<value>’

Wstawianie pierwszego rzędu

Wstawmy wartości pierwszego wiersza do tabeli emp, jak pokazano poniżej.

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

Wstaw pozostałe wiersze za pomocą polecenia put w ten sam sposób. Jeśli wstawisz całą tabelę, otrzymasz następujący wynik.

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

Wstawianie danych za pomocą Java API

Możesz wstawić dane do Hbase za pomocą add() metoda Putklasa. Możesz go zapisać za pomocąput() metoda HTableklasa. Te klasy należą doorg.apache.hadoop.hbase.clientpakiet. Poniżej podano kroki, aby utworzyć dane w tabeli HBase.

Krok 1: Utwórz wystąpienie klasy konfiguracji

Plik Configurationklasa dodaje pliki konfiguracyjne HBase do swojego obiektu. Możesz utworzyć obiekt konfiguracyjny za pomocącreate() metoda HbaseConfiguration klasa, jak pokazano poniżej.

Configuration conf = HbaseConfiguration.create();

Krok 2: Utwórz wystąpienie klasy HTable

Masz klasę o nazwie HTable, implementacja tabeli w HBase. Ta klasa służy do komunikacji z pojedynczą tabelą HBase. Podczas tworzenia instancji tej klasy przyjmuje obiekt konfiguracyjny i nazwę tabeli jako parametry. Możesz utworzyć instancję klasy HTable, jak pokazano poniżej.

HTable hTable = new HTable(conf, tableName);

Krok 3: Utwórz wystąpienie PutClass

Aby wstawić dane do tabeli HBase, plik add()metoda i jej warianty. Ta metoda należy doPut, dlatego utwórz wystąpienie klasy put. Ta klasa wymaga nazwy wiersza, do którego chcesz wstawić dane, w formacie ciągu. Możesz utworzyć wystąpieniePut klasa, jak pokazano poniżej.

Put p = new Put(Bytes.toBytes("row1"));

Krok 4: Wstaw dane

Plik add() metoda Putklasa służy do wstawiania danych. Wymaga 3-bajtowych tablic reprezentujących odpowiednio rodzinę kolumn, kwalifikator kolumny (nazwę kolumny) i wartość do wstawienia. Wstaw dane do tabeli HBase za pomocą metody add (), jak pokazano poniżej.

p.add(Bytes.toBytes("coloumn family "), Bytes.toBytes("column
name"),Bytes.toBytes("value"));

Krok 5: Zapisz dane w tabeli

Po wstawieniu wymaganych wierszy zapisz zmiany, dodając wystąpienie put do pliku put() metoda klasy HTable, jak pokazano poniżej.

hTable.put(p);

Krok 6: Zamknij instancję HTable

Po utworzeniu danych w tabeli HBase zamknij plik HTable wystąpienie przy użyciu close() metoda, jak pokazano poniżej.

hTable.close();

Poniżej podano kompletny program do tworzenia danych w tabeli 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();
   }
}

Skompiluj i wykonaj powyższy program, jak pokazano poniżej.

$javac InsertData.java
$java InsertData

Wynik powinien być następujący:

data inserted