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