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