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