HBase - Tabel Daftar
Mendaftar Tabel menggunakan HBase Shell
list adalah perintah yang digunakan untuk mendaftar semua tabel di HBase. Diberikan di bawah ini adalah sintaks dari perintah daftar.
hbase(main):001:0 > list
Ketika Anda mengetik perintah ini dan mengeksekusi di prompt HBase, itu akan menampilkan daftar semua tabel di HBase seperti yang ditunjukkan di bawah ini.
hbase(main):001:0> list
TABLE
emp
Di sini Anda dapat mengamati tabel bernama emp.
Daftar Tabel Menggunakan Java API
Ikuti langkah-langkah yang diberikan di bawah ini untuk mendapatkan daftar tabel dari HBase menggunakan java API.
Langkah 1
Anda memiliki metode yang disebut listTables() di dalam kelas HBaseAdminuntuk mendapatkan daftar semua tabel di HBase. Metode ini mengembalikan larikHTableDescriptor benda.
//creating a configuration object
Configuration conf = HBaseConfiguration.create();
//Creating HBaseAdmin object
HBaseAdmin admin = new HBaseAdmin(conf);
//Getting all the list of tables using HBaseAdmin object
HTableDescriptor[] tableDescriptor = admin.listTables();
Langkah 2
Anda bisa mendapatkan panjang file HTableDescriptor[] array menggunakan variabel panjang dari HTableDescriptorkelas. Dapatkan nama tabel dari objek ini menggunakangetNameAsString()metode. Jalankan loop 'for' menggunakan ini dan dapatkan daftar tabel di HBase.
Diberikan di bawah ini adalah program untuk membuat daftar semua tabel di HBase menggunakan Java API.
import java.io.IOException;
import org.apache.hadoop.conf.Configuration;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.client.HBaseAdmin;
public class ListTables {
public static void main(String args[])throws MasterNotRunningException, IOException{
// Instantiating a configuration class
Configuration conf = HBaseConfiguration.create();
// Instantiating HBaseAdmin class
HBaseAdmin admin = new HBaseAdmin(conf);
// Getting all the list of tables using HBaseAdmin object
HTableDescriptor[] tableDescriptor = admin.listTables();
// printing all the table names.
for (int i=0; i<tableDescriptor.length;i++ ){
System.out.println(tableDescriptor[i].getNameAsString());
}
}
}
Kompilasi dan jalankan program di atas seperti yang ditunjukkan di bawah ini.
$javac ListTables.java
$java ListTables
Outputnya adalah sebagai berikut:
User
emp