HBase - อธิบายและแก้ไข

อธิบาย

คำสั่งนี้ส่งคืนคำอธิบายของตาราง ไวยากรณ์มีดังนี้:

hbase> describe 'table name'

ด้านล่างเป็นผลลัพธ์ของคำสั่งอธิบายบนไฟล์ emp ตาราง.

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

เปลี่ยนแปลง

Alter เป็นคำสั่งที่ใช้ในการเปลี่ยนแปลงตารางที่มีอยู่ เมื่อใช้คำสั่งนี้คุณสามารถเปลี่ยนจำนวนเซลล์สูงสุดของตระกูลคอลัมน์ตั้งค่าและลบตัวดำเนินการขอบเขตตารางและลบตระกูลคอลัมน์ออกจากตารางได้

การเปลี่ยนจำนวนเซลล์สูงสุดของตระกูลคอลัมน์

ด้านล่างนี้เป็นไวยากรณ์สำหรับเปลี่ยนจำนวนเซลล์สูงสุดของตระกูลคอลัมน์

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

ในตัวอย่างต่อไปนี้จำนวนเซลล์สูงสุดถูกตั้งค่าเป็น 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

ตัวดำเนินการขอบเขตตาราง

เมื่อใช้การเปลี่ยนแปลงคุณสามารถตั้งค่าและลบตัวดำเนินการขอบเขตตารางเช่น MAX_FILESIZE, READONLY, MEMSTORE_FLUSHSIZE, DEFERRED_LOG_FLUSH เป็นต้น

การตั้งค่าอ่านอย่างเดียว

ด้านล่างนี้เป็นไวยากรณ์เพื่อให้ตารางอ่านอย่างเดียว

hbase>alter 't1', READONLY(option)

ในตัวอย่างต่อไปนี้เราได้สร้างไฟล์ emp ตารางอ่านอย่างเดียว

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

การลบตัวดำเนินการขอบเขตตาราง

เรายังสามารถลบตัวดำเนินการขอบเขตตาราง ด้านล่างนี้เป็นไวยากรณ์สำหรับลบ 'MAX_FILESIZE' จากตาราง emp

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

การลบตระกูลคอลัมน์

คุณยังสามารถลบตระกูลคอลัมน์ได้ด้วยการใช้การเปลี่ยนแปลง ให้ด้านล่างนี้คือไวยากรณ์สำหรับลบตระกูลคอลัมน์โดยใช้การเปลี่ยนแปลง

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

ให้ด้านล่างนี้เป็นตัวอย่างในการลบตระกูลคอลัมน์จากตาราง 'emp'

สมมติว่ามีตารางชื่อพนักงานใน HBase ประกอบด้วยข้อมูลต่อไปนี้:

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

ตอนนี้ให้เราลบตระกูลคอลัมน์ที่ชื่อ professional โดยใช้คำสั่ง 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

ตอนนี้ตรวจสอบข้อมูลในตารางหลังจากการเปลี่ยนแปลง สังเกตคอลัมน์ตระกูล 'มืออาชีพ' ไม่มีอีกแล้วเนื่องจากเราลบไปแล้ว

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

การเพิ่มตระกูลคอลัมน์โดยใช้ Java API

คุณสามารถเพิ่มตระกูลคอลัมน์ลงในตารางได้โดยใช้วิธี addColumn() ของ HBAseAdminชั้นเรียน ทำตามขั้นตอนด้านล่างเพื่อเพิ่มตระกูลคอลัมน์ลงในตาราง

ขั้นตอนที่ 1

เริ่มต้นไฟล์ HBaseAdmin ชั้นเรียน

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

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

ขั้นตอนที่ 2

addColumn() วิธีการต้องใช้ชื่อตารางและวัตถุของ HColumnDescriptorชั้นเรียน ดังนั้นจึงสร้างHColumnDescriptorชั้นเรียน ตัวสร้างของHColumnDescriptorในทางกลับกันต้องใช้ชื่อสกุลของคอลัมน์ที่จะเพิ่ม ที่นี่เรากำลังเพิ่มตระกูลคอลัมน์ชื่อ“ contactDetails” ในตาราง“ พนักงาน” ที่มีอยู่

// Instantiating columnDescriptor object

HColumnDescriptor columnDescriptor = new
HColumnDescriptor("contactDetails");

ขั้นตอนที่ 3

เพิ่มตระกูลคอลัมน์โดยใช้ addColumnวิธี. ส่งชื่อตารางและHColumnDescriptor คลาสอ็อบเจ็กต์เป็นพารามิเตอร์สำหรับวิธีนี้

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

ด้านล่างนี้เป็นโปรแกรมที่สมบูรณ์ในการเพิ่มตระกูลคอลัมน์ลงในตารางที่มีอยู่

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");
   }
}

คอมไพล์และรันโปรแกรมข้างต้นตามที่แสดงด้านล่าง

$javac AddColumn.java
$java AddColumn

การคอมไพล์ข้างต้นจะใช้ได้ก็ต่อเมื่อคุณตั้งค่า classpath ไว้ใน“ .bashrc”. หากคุณยังไม่ได้ทำให้ทำตามขั้นตอนด้านล่างเพื่อรวบรวมไฟล์. java ของคุณ

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

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

หากทุกอย่างเป็นไปด้วยดีมันจะให้ผลลัพธ์ดังนี้

column added

การลบตระกูลคอลัมน์โดยใช้ Java API

คุณสามารถลบตระกูลคอลัมน์ออกจากตารางโดยใช้วิธีการ deleteColumn() ของ HBAseAdminชั้นเรียน ทำตามขั้นตอนด้านล่างเพื่อเพิ่มตระกูลคอลัมน์ลงในตาราง

ขั้นตอนที่ 1

เริ่มต้นไฟล์ HBaseAdmin ชั้นเรียน

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

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

ขั้นตอนที่ 2

เพิ่มตระกูลคอลัมน์โดยใช้ deleteColumn()วิธี. ส่งชื่อตารางและชื่อตระกูลคอลัมน์เป็นพารามิเตอร์ไปยังวิธีนี้

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

ด้านล่างนี้เป็นโปรแกรมที่สมบูรณ์ในการลบตระกูลคอลัมน์จากตารางที่มีอยู่

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"); 
   }
}

คอมไพล์และรันโปรแกรมข้างต้นตามที่แสดงด้านล่าง

$javac DeleteColumn.java
$java DeleteColumn

สิ่งต่อไปนี้ควรเป็นผลลัพธ์:

column deleted