HBase-설명 및 변경

설명

이 명령은 테이블에 대한 설명을 반환합니다. 구문은 다음과 같습니다.

hbase> describe 'table name'

다음은 설명 명령의 출력입니다. emp 표.

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는 기존 테이블을 변경하는 데 사용되는 명령입니다. 이 명령을 사용하여 column family의 최대 셀 수를 변경하고 테이블 범위 연산자를 설정 및 삭제하고 테이블에서 column family를 삭제할 수 있습니다.

Column Family의 최대 셀 수 변경

다음은 column family의 최대 셀 수를 변경하는 구문입니다.

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'

Column Family 삭제

alter를 사용하여 column family를 삭제할 수도 있습니다. 다음은 alter를 사용하여 column family를 삭제하는 구문입니다.

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

아래는 'emp'테이블에서 column family를 삭제하는 예입니다.

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

이제 이름이 지정된 column family를 삭제하겠습니다. professional alter 명령을 사용합니다.

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를 사용하여 컬럼 패밀리 추가

방법을 사용하여 테이블에 column family를 추가 할 수 있습니다. addColumn()HBAseAdmin수업. 테이블에 column family를 추가하려면 아래 단계를 따르십시오.

1 단계

인스턴스화 HBaseAdmin 수업.

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

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

2 단계

그만큼 addColumn() 메소드에는 테이블 이름과 객체가 필요합니다. HColumnDescriptor수업. 따라서 인스턴스화HColumnDescriptor수업. 생성자HColumnDescriptor차례로 추가 할 열 패밀리 이름이 필요합니다. 여기서는 기존 "employee"테이블에 "contactDetails"라는 열 패밀리를 추가합니다.

// Instantiating columnDescriptor object

HColumnDescriptor columnDescriptor = new
HColumnDescriptor("contactDetails");

3 단계

다음을 사용하여 column family 추가 addColumn방법. 테이블 이름과HColumnDescriptor 이 메서드에 대한 매개 변수로 클래스 개체.

// Adding column family
admin.addColumn("employee", new HColumnDescriptor("columnDescriptor"));

다음은 기존 테이블에 column family를 추가하는 완전한 프로그램입니다.

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를 사용하여 열 패밀리 삭제

방법을 사용하여 테이블에서 column family를 삭제할 수 있습니다. deleteColumn()HBAseAdmin수업. 테이블에 column family를 추가하려면 아래 단계를 따르십시오.

1 단계

인스턴스화 HBaseAdmin 수업.

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

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

2 단계

다음을 사용하여 column family 추가 deleteColumn()방법. 테이블 이름과 컬럼 패밀리 이름을 매개 변수로이 메소드에 전달하십시오.

// Deleting column family
admin.deleteColumn("employee", "contactDetails");

다음은 기존 테이블에서 column family를 삭제하는 완전한 프로그램입니다.

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