HBase - Jelaskan & Ubah

menggambarkan

Perintah ini mengembalikan deskripsi tabel. Sintaksnya adalah sebagai berikut:

hbase> describe 'table name'

Diberikan di bawah ini adalah output dari perintah gambarkan di emp meja.

hbase(main):006:0> describe 'emp'
   DESCRIPTION
      ENABLED
      
'emp', {NAME ⇒ 'READONLY', DATA_BLOCK_ENCODING ⇒ 'NONE', BLOOMFILTER
⇒ 'ROW', REPLICATION_SCOPE ⇒ '0', COMPRESSION ⇒ 'NONE', VERSIONS ⇒
'1', TTL true

⇒ 'FOREVER', MIN_VERSIONS ⇒ '0', KEEP_DELETED_CELLS ⇒ 'false',
BLOCKSIZE ⇒ '65536', IN_MEMORY ⇒ 'false', BLOCKCACHE ⇒ 'true'}, {NAME
⇒ 'personal

data', DATA_BLOCK_ENCODING ⇒ 'NONE', BLOOMFILTER ⇒ 'ROW',
REPLICATION_SCOPE ⇒ '0', VERSIONS ⇒ '5', COMPRESSION ⇒ 'NONE',
MIN_VERSIONS ⇒ '0', TTL

⇒ 'FOREVER', KEEP_DELETED_CELLS ⇒ 'false', BLOCKSIZE ⇒ '65536',
IN_MEMORY ⇒ 'false', BLOCKCACHE ⇒ 'true'}, {NAME ⇒ 'professional
data', DATA_BLO

CK_ENCODING ⇒ 'NONE', BLOOMFILTER ⇒ 'ROW', REPLICATION_SCOPE ⇒ '0',
VERSIONS ⇒ '1', COMPRESSION ⇒ 'NONE', MIN_VERSIONS ⇒ '0', TTL ⇒
'FOREVER', K

EEP_DELETED_CELLS ⇒ 'false', BLOCKSIZE ⇒ '65536', IN_MEMORY ⇒
'false', BLOCKCACHE ⇒ 'true'}, {NAME ⇒ 'table_att_unset',
DATA_BLOCK_ENCODING ⇒ 'NO 

NE', BLOOMFILTER ⇒ 'ROW', REPLICATION_SCOPE ⇒ '0', COMPRESSION ⇒
'NONE', VERSIONS ⇒ '1', TTL ⇒ 'FOREVER', MIN_VERSIONS ⇒ '0',
KEEP_DELETED_CELLS

⇒ 'false', BLOCKSIZE ⇒ '6

mengubah

Alter adalah perintah yang digunakan untuk melakukan perubahan pada tabel yang sudah ada. Dengan menggunakan perintah ini, Anda dapat mengubah jumlah sel maksimum dari keluarga kolom, mengatur dan menghapus operator lingkup tabel, dan menghapus keluarga kolom dari tabel.

Mengubah Jumlah Sel Maksimum dari Keluarga Kolom

Diberikan di bawah ini adalah sintaks untuk mengubah jumlah sel maksimum dari keluarga kolom.

hbase> alter 't1', NAME ⇒ 'f1', VERSIONS ⇒ 5

Dalam contoh berikut, jumlah sel maksimum diatur ke 5.

hbase(main):003:0> alter 'emp', NAME ⇒ 'personal data', VERSIONS ⇒ 5
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.3050 seconds

Operator Ruang Lingkup Tabel

Dengan menggunakan alter, Anda dapat mengatur dan menghapus operator cakupan tabel seperti MAX_FILESIZE, READONLY, MEMSTORE_FLUSHSIZE, DEFERRED_LOG_FLUSH, dll.

Menyetel Hanya Baca

Di bawah ini diberikan sintaks untuk membuat tabel hanya-baca.

hbase>alter 't1', READONLY(option)

Dalam contoh berikut, kami telah membuat file emp tabel hanya baca.

hbase(main):006:0> alter 'emp', READONLY
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.2140 seconds

Menghapus Operator Table Scope

Kami juga dapat menghapus operator lingkup tabel. Diberikan di bawah ini adalah sintaks untuk menghapus 'MAX_FILESIZE' dari tabel emp.

hbase> alter 't1', METHOD ⇒ 'table_att_unset', NAME ⇒ 'MAX_FILESIZE'

Menghapus Keluarga Kolom

Dengan menggunakan alter, Anda juga dapat menghapus keluarga kolom. Diberikan di bawah ini adalah sintaks untuk menghapus keluarga kolom menggunakan alter.

hbase> alter ‘ table name ’, ‘delete’ ⇒ ‘ column family ’

Diberikan di bawah ini adalah contoh untuk menghapus keluarga kolom dari tabel 'emp'.

Asumsikan ada tabel bernama karyawan di HBase. Ini berisi data berikut:

hbase(main):006:0> scan 'employee'

   ROW                   COLUMN+CELL

row1 column = personal:city, timestamp = 1418193767, value = hyderabad

row1 column = personal:name, timestamp = 1418193806767, value = raju

row1 column = professional:designation, timestamp = 1418193767, value = manager

row1 column = professional:salary, timestamp = 1418193806767, value = 50000

1 row(s) in 0.0160 seconds

Sekarang mari kita hapus keluarga kolom bernama professional menggunakan perintah alter.

hbase(main):007:0> alter 'employee','delete'⇒'professional'
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.2380 seconds

Sekarang verifikasi data dalam tabel setelah perubahan. Perhatikan keluarga kolom 'profesional' tidak lebih, karena kami telah menghapusnya.

hbase(main):003:0> scan 'employee'
   ROW             COLUMN + CELL
row1 column = personal:city, timestamp = 14181936767, value = hyderabad

row1 column = personal:name, timestamp = 1418193806767, value = raju

1 row(s) in 0.0830 seconds

Menambahkan Keluarga Kolom Menggunakan Java API

Anda dapat menambahkan keluarga kolom ke tabel menggunakan metode ini addColumn() dari HBAseAdminkelas. Ikuti langkah-langkah yang diberikan di bawah ini untuk menambahkan keluarga kolom ke tabel.

Langkah 1

Instantiate HBaseAdmin kelas.

// Instantiating configuration object
Configuration conf = HBaseConfiguration.create();

// Instantiating HBaseAdmin class
HBaseAdmin admin = new HBaseAdmin(conf);

Langkah 2

Itu addColumn() metode membutuhkan nama tabel dan objek HColumnDescriptorkelas. Oleh karena itu buat instanceHColumnDescriptorkelas. Konstruktor dariHColumnDescriptorpada gilirannya membutuhkan nama keluarga kolom yang akan ditambahkan. Di sini kami menambahkan keluarga kolom bernama "contactDetails" ke tabel "karyawan" yang ada.

// Instantiating columnDescriptor object

HColumnDescriptor columnDescriptor = new
HColumnDescriptor("contactDetails");

LANGKAH 3

Tambahkan keluarga kolom menggunakan addColumnmetode. Berikan nama tabel danHColumnDescriptor objek kelas sebagai parameter untuk metode ini.

// Adding column family
admin.addColumn("employee", new HColumnDescriptor("columnDescriptor"));

Diberikan di bawah ini adalah program lengkap untuk menambahkan keluarga kolom ke tabel yang ada.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.client.HBaseAdmin;

public class AddColoumn{

   public static void main(String args[]) throws MasterNotRunningException, IOException{

      // Instantiating configuration class.
      Configuration conf = HBaseConfiguration.create();

      // Instantiating HBaseAdmin class.
      HBaseAdmin admin = new HBaseAdmin(conf);

      // Instantiating columnDescriptor class
      HColumnDescriptor columnDescriptor = new HColumnDescriptor("contactDetails");
      
      // Adding column family
      admin.addColumn("employee", columnDescriptor);
      System.out.println("coloumn added");
   }
}

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

$javac AddColumn.java
$java AddColumn

Kompilasi di atas hanya berfungsi jika Anda telah menyetel classpath di " .bashrc". Jika Anda belum melakukannya, ikuti prosedur yang diberikan di bawah ini untuk mengkompilasi file .java Anda.

//if "/home/home/hadoop/hbase " is your Hbase home folder then.

$javac -cp /home/hadoop/hbase/lib/*: Demo.java

Jika semuanya berjalan dengan baik, maka akan menghasilkan keluaran sebagai berikut:

column added

Menghapus Keluarga Kolom Menggunakan Java API

Anda dapat menghapus keluarga kolom dari tabel menggunakan metode ini deleteColumn() dari HBAseAdminkelas. Ikuti langkah-langkah yang diberikan di bawah ini untuk menambahkan keluarga kolom ke tabel.

Langkah 1

Instantiate HBaseAdmin kelas.

// Instantiating configuration object
Configuration conf = HBaseConfiguration.create();

// Instantiating HBaseAdmin class
HBaseAdmin admin = new HBaseAdmin(conf);

Langkah 2

Tambahkan keluarga kolom menggunakan deleteColumn()metode. Berikan nama tabel dan nama keluarga kolom sebagai parameter untuk metode ini.

// Deleting column family
admin.deleteColumn("employee", "contactDetails");

Diberikan di bawah ini adalah program lengkap untuk menghapus keluarga kolom dari tabel yang ada.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.client.HBaseAdmin;

public class DeleteColoumn{

   public static void main(String args[]) throws MasterNotRunningException, IOException{

      // Instantiating configuration class.
      Configuration conf = HBaseConfiguration.create();

      // Instantiating HBaseAdmin class.
      HBaseAdmin admin = new HBaseAdmin(conf);

      // Deleting a column family
      admin.deleteColumn("employee","contactDetails");
      System.out.println("coloumn deleted"); 
   }
}

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

$javac DeleteColumn.java
$java DeleteColumn

Outputnya adalah sebagai berikut:

column deleted