HBase-테이블 생성
HBase 셸을 사용하여 테이블 생성
다음을 사용하여 테이블을 만들 수 있습니다. create여기에서 테이블 이름과 열 패밀리 이름을 지정해야합니다. 그만큼syntax HBase 셸에서 테이블을 만드는 방법은 다음과 같습니다.
create ‘<table name>’,’<column family>’
예
다음은 emp라는 테이블의 샘플 스키마입니다. 여기에는 "개인 데이터"와 "전문 데이터"의 두 가지 열 패밀리가 있습니다.
행 키 | 개인 정보 | 전문 데이터 |
---|---|---|
다음과 같이 HBase 셸에서이 테이블을 만들 수 있습니다.
hbase(main):002:0> create 'emp', 'personal data', 'professional data'
그리고 다음과 같은 출력을 제공합니다.
0 row(s) in 1.1300 seconds
=> Hbase::Table - emp
확인
다음을 사용하여 테이블이 생성되었는지 확인할 수 있습니다. list아래와 같이 명령. 여기에서 생성 된 emp 테이블을 관찰 할 수 있습니다.
hbase(main):002:0> list
TABLE
emp
2 row(s) in 0.0340 seconds
Java API를 사용하여 테이블 생성
다음을 사용하여 HBase에서 테이블을 만들 수 있습니다. createTable() 의 방법 HBaseAdmin수업. 이 클래스는org.apache.hadoop.hbase.client꾸러미. 다음은 Java API를 사용하여 HBase에서 테이블을 만드는 단계입니다.
1 단계 : HBaseAdmin 인스턴스화
이 클래스에는 Configuration 개체가 매개 변수로 필요하므로 처음에 Configuration 클래스를 인스턴스화하고이 인스턴스를 HBaseAdmin에 전달합니다.
Configuration conf = HBaseConfiguration.create();
HBaseAdmin admin = new HBaseAdmin(conf);
2 단계 : TableDescriptor 만들기
HTableDescriptor 에 속하는 클래스입니다 org.apache.hadoop.hbase수업. 이 클래스는 테이블 이름 및 열 그룹의 컨테이너와 같습니다.
//creating table descriptor
HTableDescriptor table = new HTableDescriptor(toBytes("Table name"));
//creating column family descriptor
HColumnDescriptor family = new HColumnDescriptor(toBytes("column family"));
//adding coloumn family to HTable
table.addFamily(family);
3 단계 : 관리자를 통해 실행
사용 createTable() 의 방법 HBaseAdmin 생성 된 테이블을 관리 모드에서 실행할 수 있습니다.
admin.createTable(table);
아래는 관리자를 통해 테이블을 만드는 완전한 프로그램입니다.
import java.io.IOException;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.HColumnDescriptor;
import org.apache.hadoop.hbase.HTableDescriptor;
import org.apache.hadoop.hbase.client.HBaseAdmin;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.conf.Configuration;
public class CreateTable {
public static void main(String[] args) throws IOException {
// Instantiating configuration class
Configuration con = HBaseConfiguration.create();
// Instantiating HbaseAdmin class
HBaseAdmin admin = new HBaseAdmin(con);
// Instantiating table descriptor class
HTableDescriptor tableDescriptor = new
HTableDescriptor(TableName.valueOf("emp"));
// Adding column families to table descriptor
tableDescriptor.addFamily(new HColumnDescriptor("personal"));
tableDescriptor.addFamily(new HColumnDescriptor("professional"));
// Execute the table through admin
admin.createTable(tableDescriptor);
System.out.println(" Table created ");
}
}
위의 프로그램을 아래와 같이 컴파일하고 실행합니다.
$javac CreateTable.java
$java CreateTable
다음은 출력이어야합니다.
Table created