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