HBase - Buat Data

Memasukkan Data menggunakan HBase Shell

Bab ini menunjukkan cara membuat data dalam tabel HBase. Untuk membuat data dalam tabel HBase, perintah dan metode berikut digunakan:

  • put perintah,

  • add() metode dari Put kelas, dan

  • put() metode dari HTable kelas.

Sebagai contoh, kita akan membuat tabel berikut di HBase.

Menggunakan putperintah, Anda dapat memasukkan baris ke dalam tabel. Sintaksnya adalah sebagai berikut:

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

Memasukkan Baris Pertama

Mari kita masukkan nilai baris pertama ke dalam tabel emp seperti yang ditunjukkan di bawah ini.

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

Masukkan baris yang tersisa menggunakan perintah put dengan cara yang sama. Jika Anda memasukkan seluruh tabel, Anda akan mendapatkan output berikut.

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

Memasukkan Data Menggunakan Java API

Anda dapat memasukkan data ke Hbase menggunakan add() metode dari Putkelas. Anda dapat menyimpannya menggunakanput() metode dari HTablekelas. Kelas-kelas ini milikorg.apache.hadoop.hbase.clientpaket. Di bawah ini diberikan adalah langkah-langkah untuk membuat data dalam Tabel HBase.

Langkah 1: Buat instance Kelas Konfigurasi

Itu Configurationkelas menambahkan file konfigurasi HBase ke objeknya. Anda dapat membuat objek konfigurasi menggunakancreate() metode dari HbaseConfiguration kelas seperti yang ditunjukkan di bawah ini.

Configuration conf = HbaseConfiguration.create();

Langkah 2: Buat instance Kelas HTable

Anda memiliki kelas yang disebut HTable, implementasi Tabel di HBase. Kelas ini digunakan untuk berkomunikasi dengan tabel HBase tunggal. Saat membuat instance kelas ini, ia menerima objek konfigurasi dan nama tabel sebagai parameter. Anda dapat membuat instance kelas HTable seperti yang ditunjukkan di bawah ini.

HTable hTable = new HTable(conf, tableName);

Langkah 3: Buat instance PutClass

Untuk memasukkan data ke dalam tabel HBase, file add()metode dan variannya digunakan. Metode ini milikPut, oleh karena itu instantiate kelas put. Kelas ini membutuhkan nama baris yang ingin Anda masukkan datanya, dalam format string. Anda dapat membuat instancePut kelas seperti yang ditunjukkan di bawah ini.

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

Langkah 4: Masukkan Data

Itu add() metode dari Putkelas digunakan untuk memasukkan data. Ini membutuhkan 3 array byte yang mewakili keluarga kolom, kualifikasi kolom (nama kolom), dan nilai yang akan disisipkan. Masukkan data ke dalam tabel HBase menggunakan metode add () seperti yang ditunjukkan di bawah ini.

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

Langkah 5: Simpan Data dalam Tabel

Setelah memasukkan baris yang diperlukan, simpan perubahan dengan menambahkan contoh put ke put() metode kelas HTable seperti yang ditunjukkan di bawah ini.

hTable.put(p);

Langkah 6: Tutup Instans HTable

Setelah membuat data di Tabel HBase, tutup file HTable Misalnya menggunakan close() metode seperti yang ditunjukkan di bawah ini.

hTable.close();

Diberikan di bawah ini adalah program lengkap untuk membuat data dalam Tabel 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();
   }
}

Kompilasi dan jalankan program di atas seperti yang ditunjukkan di bawah ini.

$javac InsertData.java
$java InsertData

Outputnya adalah sebagai berikut:

data inserted