HBase - สร้างตาราง
การสร้างตารางโดยใช้ HBase Shell
คุณสามารถสร้างตารางโดยใช้ไฟล์ createคุณต้องระบุชื่อตารางและชื่อตระกูลคอลัมน์ที่นี่ syntax เพื่อสร้างตารางใน HBase shell ดังแสดงด้านล่าง
create ‘<table name>’,’<column family>’
ตัวอย่าง
ด้านล่างนี้เป็นตัวอย่างสคีมาของตารางชื่อ emp มีคอลัมน์สองตระกูล ได้แก่ "ข้อมูลส่วนบุคคล" และ "ข้อมูลระดับมืออาชีพ"
คีย์แถว | ข้อมูลส่วนบุคคล | ข้อมูลระดับมืออาชีพ |
---|---|---|
คุณสามารถสร้างตารางนี้ใน HBase shell ดังที่แสดงด้านล่าง
hbase(main):002:0> create 'emp', 'personal data', 'professional data'
และจะให้ผลลัพธ์ดังต่อไปนี้
0 row(s) in 1.1300 seconds
=> Hbase::Table - emp
การยืนยัน
คุณสามารถตรวจสอบได้ว่าตารางถูกสร้างขึ้นโดยใช้ไฟล์ listคำสั่งดังที่แสดงด้านล่าง ที่นี่คุณสามารถสังเกตตาราง emp ที่สร้างขึ้น
hbase(main):002:0> list
TABLE
emp
2 row(s) in 0.0340 seconds
การสร้างตารางโดยใช้ java API
คุณสามารถสร้างตารางใน HBase โดยใช้ไฟล์ createTable() วิธีการของ HBaseAdminชั้นเรียน คลาสนี้เป็นของorg.apache.hadoop.hbase.clientแพ็คเกจ ด้านล่างนี้เป็นขั้นตอนในการสร้างตารางใน HBase โดยใช้ java API
ขั้นตอนที่ 1: สร้างอินสแตนซ์ HBaseAdmin
คลาสนี้ต้องการอ็อบเจ็กต์คอนฟิกูเรชันเป็นพารามิเตอร์ดังนั้นในขั้นต้นจึงสร้างอินสแตนซ์คลาสคอนฟิกูเรชันและส่งอินสแตนซ์นี้ไปยัง HBaseAdmin
Configuration conf = HBaseConfiguration.create();
HBaseAdmin admin = new HBaseAdmin(conf);
ขั้นตอนที่ 2: สร้าง TableDescriptor
HTableDescriptor เป็นคลาสที่เป็นของ org.apache.hadoop.hbaseชั้นเรียน คลาสนี้เป็นเหมือนที่เก็บของชื่อตารางและตระกูลคอลัมน์
//creating table descriptor
HTableDescriptor table = new HTableDescriptor(toBytes("Table name"));
//creating column family descriptor
HColumnDescriptor family = new HColumnDescriptor(toBytes("column family"));
//adding coloumn family to HTable
table.addFamily(family);
ขั้นตอนที่ 3: ดำเนินการผ่านผู้ดูแลระบบ
ใช้ createTable() วิธีการของ HBaseAdmin คลาสคุณสามารถเรียกใช้ตารางที่สร้างขึ้นในโหมดผู้ดูแลระบบ
admin.createTable(table);
ด้านล่างนี้เป็นโปรแกรมที่สมบูรณ์ในการสร้างตารางผ่านทางผู้ดูแลระบบ
import java.io.IOException;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.conf.Configuration;
public class CreateTable {
public static void main(String[] args) throws IOException {
// Instantiating configuration class
Configuration con = HBaseConfiguration.create();
// Instantiating HbaseAdmin class
HBaseAdmin admin = new HBaseAdmin(con);
// Instantiating table descriptor class
HTableDescriptor tableDescriptor = new
HTableDescriptor(TableName.valueOf("emp"));
// Adding column families to table descriptor
tableDescriptor.addFamily(new HColumnDescriptor("personal"));
tableDescriptor.addFamily(new HColumnDescriptor("professional"));
// Execute the table through admin
admin.createTable(tableDescriptor);
System.out.println(" Table created ");
}
}
คอมไพล์และรันโปรแกรมข้างต้นตามที่แสดงด้านล่าง
$javac CreateTable.java
$java CreateTable
สิ่งต่อไปนี้ควรเป็นผลลัพธ์:
Table created