HBase - ลบข้อมูล

การลบเซลล์เฉพาะในตาราง

ใช้ deleteคำสั่งคุณสามารถลบเซลล์เฉพาะในตาราง ไวยากรณ์ของdelete คำสั่งมีดังนี้:

delete ‘<table name>’, ‘<row>’, ‘<column name >’, ‘<time stamp>’

ตัวอย่าง

นี่คือตัวอย่างการลบเซลล์เฉพาะ นี่เรากำลังลบเงินเดือน

hbase(main):006:0> delete 'emp', '1', 'personal data:city',
1417521848375
0 row(s) in 0.0060 seconds

การลบเซลล์ทั้งหมดในตาราง

ใช้คำสั่ง“ deleteall” คุณสามารถลบเซลล์ทั้งหมดในแถว ให้ด้านล่างเป็นไวยากรณ์ของคำสั่ง deleteall

deleteall ‘<table name>’, ‘<row>’,

ตัวอย่าง

นี่คือตัวอย่างของคำสั่ง“ deleteall” ซึ่งเรากำลังลบเซลล์ทั้งหมดของ row1 ของตาราง emp

hbase(main):007:0> deleteall 'emp','1'
0 row(s) in 0.0240 seconds

ตรวจสอบตารางโดยใช้ scanคำสั่ง ภาพรวมของตารางหลังจากลบตารางจะได้รับด้านล่าง

hbase(main):022:0> scan 'emp'

ROW                  COLUMN + CELL

2 column = personal data:city, timestamp = 1417524574905, value = chennai 

2 column = personal data:name, timestamp = 1417524556125, value = ravi

2 column = professional data:designation, timestamp = 1417524204, value = sr:engg

2 column = professional data:salary, timestamp = 1417524604221, value = 30000

3 column = personal data:city, timestamp = 1417524681780, value = delhi

3 column = personal data:name, timestamp = 1417524672067, value = rajesh
 
3 column = professional data:designation, timestamp = 1417523187, value = jr:engg

3 column = professional data:salary, timestamp = 1417524702514, value = 25000

การลบข้อมูลโดยใช้ Java API

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

ขั้นตอนที่ 1: สร้างอินสแตนซ์คลาสการกำหนดค่า

Configurationคลาสเพิ่มไฟล์คอนฟิกูเรชัน HBase ให้กับอ็อบเจ็กต์ คุณสามารถสร้างวัตถุคอนฟิกูเรชันโดยใช้ไฟล์create() วิธีการของ HbaseConfiguration คลาสดังที่แสดงด้านล่าง

Configuration conf = HbaseConfiguration.create();

ขั้นตอนที่ 2: สร้างคลาส HTable

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

HTable hTable = new HTable(conf, tableName);

ขั้นตอนที่ 3: สร้างขั้นตอนการลบคลาส

เริ่มต้นไฟล์ Deleteคลาสโดยส่ง rowid ของแถวที่จะลบในรูปแบบไบต์อาร์เรย์ คุณยังสามารถส่งการประทับเวลาและ Rowlock ไปยังตัวสร้างนี้ได้

Delete delete = new Delete(toBytes("row1"));

ขั้นตอนที่ 4: เลือกข้อมูลที่จะลบ

คุณสามารถลบข้อมูลโดยใช้วิธีการลบของไฟล์ Deleteชั้นเรียน คลาสนี้มีวิธีการลบต่างๆ เลือกคอลัมน์หรือตระกูลคอลัมน์ที่จะลบโดยใช้วิธีการเหล่านั้น ดูตัวอย่างต่อไปนี้ที่แสดงการใช้เมธอด Delete class

delete.deleteColumn(Bytes.toBytes("personal"), Bytes.toBytes("name"));
delete.deleteFamily(Bytes.toBytes("professional"));

ขั้นตอนที่ 5: ลบข้อมูล

ลบข้อมูลที่เลือกโดยส่งไฟล์ delete อินสแตนซ์ไปยังไฟล์ delete() วิธีการของ HTable คลาสดังที่แสดงด้านล่าง

table.delete(delete);

ขั้นตอนที่ 6: ปิด HTableInstance

หลังจากลบข้อมูลแล้วให้ปิดไฟล์ HTable ตัวอย่าง.

table.close();

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

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.client.Delete;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.util.Bytes;

public class DeleteData {

   public static void main(String[] args) throws IOException {

      // Instantiating Configuration class
      Configuration conf = HBaseConfiguration.create();

      // Instantiating HTable class
      HTable table = new HTable(conf, "employee");

      // Instantiating Delete class
      Delete delete = new Delete(Bytes.toBytes("row1"));
      delete.deleteColumn(Bytes.toBytes("personal"), Bytes.toBytes("name"));
      delete.deleteFamily(Bytes.toBytes("professional"));

      // deleting the data
      table.delete(delete);

      // closing the HTable object
      table.close();
      System.out.println("data deleted.....");
   }
}

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

$javac Deletedata.java
$java DeleteData

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

data deleted