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