Hbase-describe-and-alter

提供:Dev Guides
移動先:案内検索

HBase-説明と変更

記述する

このコマンドは、テーブルの説明を返します。 その構文は次のとおりです。

hbase> describe 'table name'

以下に、 emp テーブルでのdescribeコマンドの出力を示します。

hbase(main):006:0> describe 'emp'
   DESCRIPTION
      ENABLED

'emp', {NAME ⇒ 'READONLY', DATA_BLOCK_ENCODING ⇒ 'NONE', BLOOMFILTER
⇒ 'ROW', REPLICATION_SCOPE ⇒ '0', COMPRESSION ⇒ 'NONE', VERSIONS ⇒
'1', TTL true

⇒ 'FOREVER', MIN_VERSIONS ⇒ '0', KEEP_DELETED_CELLS ⇒ 'false',
BLOCKSIZE ⇒ '65536', IN_MEMORY ⇒ 'false', BLOCKCACHE ⇒ 'true'}, {NAME
⇒ 'personal

data', DATA_BLOCK_ENCODING ⇒ 'NONE', BLOOMFILTER ⇒ 'ROW',
REPLICATION_SCOPE ⇒ '0', VERSIONS ⇒ '5', COMPRESSION ⇒ 'NONE',
MIN_VERSIONS ⇒ '0', TTL

⇒ 'FOREVER', KEEP_DELETED_CELLS ⇒ 'false', BLOCKSIZE ⇒ '65536',
IN_MEMORY ⇒ 'false', BLOCKCACHE ⇒ 'true'}, {NAME ⇒ 'professional
data', DATA_BLO

CK_ENCODING ⇒ 'NONE', BLOOMFILTER ⇒ 'ROW', REPLICATION_SCOPE ⇒ '0',
VERSIONS ⇒ '1', COMPRESSION ⇒ 'NONE', MIN_VERSIONS ⇒ '0', TTL ⇒
'FOREVER', K

EEP_DELETED_CELLS ⇒ 'false', BLOCKSIZE ⇒ '65536', IN_MEMORY ⇒
'false', BLOCKCACHE ⇒ 'true'}, {NAME ⇒ 'table_att_unset',
DATA_BLOCK_ENCODING ⇒ 'NO

NE', BLOOMFILTER ⇒ 'ROW', REPLICATION_SCOPE ⇒ '0', COMPRESSION ⇒
'NONE', VERSIONS ⇒ '1', TTL ⇒ 'FOREVER', MIN_VERSIONS ⇒ '0',
KEEP_DELETED_CELLS

⇒ 'false', BLOCKSIZE ⇒ '6

変える

Alterは、既存のテーブルに変更を加えるために使用されるコマンドです。 このコマンドを使用すると、列ファミリのセルの最大数を変更したり、テーブルスコープ演算子を設定および削除したり、テーブルから列ファミリを削除したりできます。

列ファミリのセルの最大数の変更

以下は、列ファミリのセルの最大数を変更する構文です。

hbase> alter 't1', NAME ⇒ 'f1', VERSIONS ⇒ 5

次の例では、セルの最大数は5に設定されています。

hbase(main):003:0> alter 'emp', NAME ⇒ 'personal data', VERSIONS ⇒ 5
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.3050 seconds

テーブルスコープ演算子

alterを使用すると、MAX_FILESIZE、READONLY、MEMSTORE_FLUSHSIZE、DEFERRED_LOG_FLUSHなどのテーブルスコープ演算子を設定および削除できます。

読み取り専用の設定

以下は、テーブルを読み取り専用にする構文です。

hbase>alter 't1', READONLY(option)

次の例では、 emp テーブルを読み取り専用にしました。

hbase(main):006:0> alter 'emp', READONLY
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.2140 seconds

テーブルスコープ演算子の削除

テーブルスコープ演算子を削除することもできます。 以下は、empテーブルから「MAX_FILESIZE」を削除する構文です。

hbase> alter 't1', METHOD ⇒ 'table_att_unset', NAME ⇒ 'MAX_FILESIZE'

列ファミリーの削除

alterを使用して、列ファミリを削除することもできます。 以下に、alterを使用して列ファミリを削除する構文を示します。

hbase> alter ‘ table name ’, ‘delete’ ⇒ ‘ column family ’

以下は、「emp」テーブルから列ファミリを削除する例です。

HBaseにemployeeという名前のテーブルがあると仮定します。 次のデータが含まれます。

hbase(main):006:0> scan 'employee'

   ROW                   COLUMN+CELL

row1 column = personal:city, timestamp = 1418193767, value = hyderabad

row1 column = personal:name, timestamp = 1418193806767, value = raju

row1 column = professional:designation, timestamp = 1418193767, value = manager

row1 column = professional:salary, timestamp = 1418193806767, value = 50000

1 row(s) in 0.0160 seconds

次に、alterコマンドを使用して professional という名前の列ファミリを削除します。

hbase(main):007:0> alter 'employee','delete'⇒'professional'
Updating all regions with the new schema...
0/1 regions updated.
1/1 regions updated.
Done.
0 row(s) in 2.2380 seconds

変更後、テーブル内のデータを確認します。 コラムファミリ「professional」は削除されているため、もはや存在しません。

hbase(main):003:0> scan 'employee'
   ROW             COLUMN + CELL
row1 column = personal:city, timestamp = 14181936767, value = hyderabad

row1 column = personal:name, timestamp = 1418193806767, value = raju

1 row(s) in 0.0830 seconds

Java APIを使用した列ファミリの追加

*HBAseAdmin* クラスの* addColumn()*メソッドを使用して、テーブルに列ファミリを追加できます。 以下の手順に従って、列ファミリをテーブルに追加します。

ステップ1

*HBaseAdmin* クラスをインスタンス化します。
//Instantiating configuration object
Configuration conf = HBaseConfiguration.create();

//Instantiating HBaseAdmin class
HBaseAdmin admin = new HBaseAdmin(conf);

ステップ2

  • addColumn()メソッドには、テーブル名と *HColumnDescriptor クラスのオブジェクトが必要です。 したがって、 HColumnDescriptor クラスをインスタンス化します。 また、 HColumnDescriptor のコンストラクターには、追加する列ファミリ名が必要です。 ここでは、「contactDetails」という名前の列ファミリを既存の「employee」テーブルに追加しています。
//Instantiating columnDescriptor object

HColumnDescriptor columnDescriptor = new
HColumnDescriptor("contactDetails");

ステップ3

*addColumn* メソッドを使用して列ファミリを追加します。 テーブル名と *HColumnDescriptor* クラスオブジェクトをパラメーターとしてこのメ​​ソッドに渡します。
//Adding column family
admin.addColumn("employee", new HColumnDescriptor("columnDescriptor"));

以下は、既存のテーブルに列ファミリを追加するための完全なプログラムです。

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.client.HBaseAdmin;

public class AddColoumn{

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

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

     //Instantiating HBaseAdmin class.
      HBaseAdmin admin = new HBaseAdmin(conf);

     //Instantiating columnDescriptor class
      HColumnDescriptor columnDescriptor = new HColumnDescriptor("contactDetails");

     //Adding column family
      admin.addColumn("employee", columnDescriptor);
      System.out.println("coloumn added");
   }
}

以下に示すように、上記のプログラムをコンパイルして実行します。

$javac AddColumn.java
$java AddColumn

上記のコンパイルは、「 .bashrc 」でクラスパスを設定した場合にのみ機能します。 そうでない場合は、以下の手順に従って.javaファイルをコンパイルします。

//if "/home/home/hadoop/hbase " is your Hbase home folder then.

$javac -cp/home/hadoop/hbase/lib/*: Demo.java

すべてがうまくいけば、次の出力が生成されます。

column added

Java APIを使用した列ファミリの削除

*HBAseAdmin* クラスの* deleteColumn()*メソッドを使用して、テーブルから列ファミリを削除できます。 以下の手順に従って、列ファミリをテーブルに追加します。

ステップ1

*HBaseAdmin* クラスをインスタンス化します。
//Instantiating configuration object
Configuration conf = HBaseConfiguration.create();

//Instantiating HBaseAdmin class
HBaseAdmin admin = new HBaseAdmin(conf);

ステップ2

  • deleteColumn()*メソッドを使用して列ファミリーを追加します。 テーブル名と列ファミリ名をパラメータとしてこのメ​​ソッドに渡します。
//Deleting column family
admin.deleteColumn("employee", "contactDetails");

以下に、既存のテーブルから列ファミリを削除する完全なプログラムを示します。

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.MasterNotRunningException;
import org.apache.hadoop.hbase.client.HBaseAdmin;

public class DeleteColoumn{

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

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

     //Instantiating HBaseAdmin class.
      HBaseAdmin admin = new HBaseAdmin(conf);

     //Deleting a column family
      admin.deleteColumn("employee","contactDetails");
      System.out.println("coloumn deleted");
   }
}

以下に示すように、上記のプログラムをコンパイルして実行します。

$javac DeleteColumn.java
$java DeleteColumn

出力は次のようになります。

column deleted