HBase - อ่านข้อมูล
การอ่านข้อมูลโดยใช้ HBase Shell
get คำสั่งและ get() วิธีการของ HTableคลาสใช้อ่านข้อมูลจากตารางใน HBase การใช้getคำสั่งคุณจะได้รับข้อมูลทีละแถว ไวยากรณ์มีดังนี้:
get ’<table name>’,’row1’
ตัวอย่าง
ตัวอย่างต่อไปนี้แสดงวิธีใช้คำสั่ง get ให้เราสแกนแถวแรกของไฟล์emp ตาราง.
hbase(main):012:0> get 'emp', '1'
COLUMN CELL
personal : city timestamp = 1417521848375, value = hyderabad
personal : name timestamp = 1417521785385, value = ramu
professional: designation timestamp = 1417521885277, value = manager
professional: salary timestamp = 1417521903862, value = 50000
4 row(s) in 0.0270 seconds
การอ่านคอลัมน์เฉพาะ
ให้ด้านล่างเป็นไวยากรณ์สำหรับอ่านคอลัมน์เฉพาะโดยใช้ get วิธี.
hbase> get 'table name', ‘rowid’, {COLUMN ⇒ ‘column family:column name ’}
ตัวอย่าง
ให้ด้านล่างนี้เป็นตัวอย่างในการอ่านคอลัมน์เฉพาะในตาราง HBase
hbase(main):015:0> get 'emp', 'row1', {COLUMN ⇒ 'personal:name'}
COLUMN CELL
personal:name timestamp = 1418035791555, value = raju
1 row(s) in 0.0080 seconds
การอ่านข้อมูลโดยใช้ Java API
หากต้องการอ่านข้อมูลจากตาราง HBase ให้ใช้ไฟล์ get()วิธีการของคลาส HTable วิธีนี้ต้องการอินสแตนซ์ของไฟล์Getชั้นเรียน ทำตามขั้นตอนด้านล่างเพื่อดึงข้อมูลจากตาราง HBase
ขั้นตอนที่ 1: สร้างอินสแตนซ์คลาสการกำหนดค่า
Configurationคลาสเพิ่มไฟล์คอนฟิกูเรชัน HBase ให้กับอ็อบเจ็กต์ คุณสามารถสร้างวัตถุคอนฟิกูเรชันโดยใช้ไฟล์create() วิธีการของ HbaseConfiguration คลาสดังที่แสดงด้านล่าง
Configuration conf = HbaseConfiguration.create();
ขั้นตอนที่ 2: สร้างคลาส HTable
คุณมีคลาสที่เรียกว่า HTableการใช้งาน Table ใน HBase คลาสนี้ใช้เพื่อสื่อสารกับตาราง HBase เดียว ในขณะที่สร้างอินสแตนซ์คลาสนี้จะยอมรับออบเจ็กต์คอนฟิกูเรชันและชื่อตารางเป็นพารามิเตอร์ คุณสามารถสร้างอินสแตนซ์คลาส HTable ได้ดังที่แสดงด้านล่าง
HTable hTable = new HTable(conf, tableName);
ขั้นตอนที่ 3: สร้างอินสแตนซ์รับคลาส
คุณสามารถดึงข้อมูลจากตาราง HBase โดยใช้ไฟล์ get() วิธีการของ HTableชั้นเรียน วิธีนี้ดึงเซลล์จากแถวที่กำหนด ต้องใช้ไฟล์Getคลาสอ็อบเจ็กต์เป็นพารามิเตอร์ สร้างตามที่แสดงด้านล่าง
Get get = new Get(toBytes("row1"));
ขั้นตอนที่ 4: อ่านข้อมูล
ในขณะที่ดึงข้อมูลคุณสามารถรับแถวเดียวโดยใช้ id หรือรับชุดของแถวตามชุดรหัสแถวหรือสแกนทั้งตารางหรือส่วนย่อยของแถว
คุณสามารถดึงข้อมูลตาราง HBase โดยใช้ตัวแปรวิธีการเพิ่มใน Get ชั้นเรียน
หากต้องการรับคอลัมน์เฉพาะจากกลุ่มคอลัมน์เฉพาะให้ใช้วิธีการต่อไปนี้
get.addFamily(personal)
หากต้องการรับคอลัมน์ทั้งหมดจากกลุ่มคอลัมน์เฉพาะให้ใช้วิธีการต่อไปนี้
get.addColumn(personal, name)
ขั้นตอนที่ 5: รับผลลัพธ์
รับผลลัพธ์โดยส่งไฟล์ Get คลาสอินสแตนซ์ไปยังเมธอด get ของ HTableชั้นเรียน วิธีนี้ส่งคืนไฟล์Resultคลาสอ็อบเจ็กต์ซึ่งเก็บผลลัพธ์ที่ร้องขอ ด้านล่างคือการใช้งานของget() วิธี.
Result result = table.get(g);
ขั้นตอนที่ 6: การอ่านค่าจากอินสแตนซ์ผลลัพธ์
Result คลาสให้ไฟล์ getValue()วิธีการอ่านค่าจากอินสแตนซ์ ใช้ตามที่แสดงด้านล่างเพื่ออ่านค่าจากไฟล์Result ตัวอย่าง.
byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));
byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));
ด้านล่างนี้เป็นโปรแกรมที่สมบูรณ์ในการอ่านค่าจากตาราง HBase
import java.io.IOException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.util.Bytes;
public class RetriveData{
public static void main(String[] args) throws IOException, Exception{
// Instantiating Configuration class
Configuration config = HBaseConfiguration.create();
// Instantiating HTable class
HTable table = new HTable(config, "emp");
// Instantiating Get class
Get g = new Get(Bytes.toBytes("row1"));
// Reading the data
Result result = table.get(g);
// Reading values from Result class object
byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));
byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));
// Printing the values
String name = Bytes.toString(value);
String city = Bytes.toString(value1);
System.out.println("name: " + name + " city: " + city);
}
}
คอมไพล์และรันโปรแกรมข้างต้นตามที่แสดงด้านล่าง
$javac RetriveData.java
$java RetriveData
สิ่งต่อไปนี้ควรเป็นผลลัพธ์:
name: Raju city: Delhi