HBase-데이터 읽기

HBase Shell을 사용하여 데이터 읽기

그만큼 get 명령 및 get() 의 방법 HTable클래스는 HBase의 테이블에서 데이터를 읽는 데 사용됩니다. 사용get명령을 사용하면 한 번에 한 행의 데이터를 가져올 수 있습니다. 구문은 다음과 같습니다.

get ’<table name>’,’row1’

다음 예는 get 명령을 사용하는 방법을 보여줍니다. 첫 번째 행을 스캔하겠습니다.emp 표.

hbase(main):012:0> get 'emp', '1'

   COLUMN                     CELL
   
personal : city timestamp = 1417521848375, value = hyderabad

personal : name timestamp = 1417521785385, value = ramu

professional: designation timestamp = 1417521885277, value = manager

professional: salary timestamp = 1417521903862, value = 50000

4 row(s) in 0.0270 seconds

특정 열 읽기

다음은 다음을 사용하여 특정 열을 읽는 구문입니다. get 방법.

hbase> get 'table name', ‘rowid’, {COLUMN ⇒ ‘column family:column name ’}

다음은 HBase 테이블의 특정 열을 읽는 예입니다.

hbase(main):015:0> get 'emp', 'row1', {COLUMN ⇒ 'personal:name'}
  COLUMN                CELL  
personal:name timestamp = 1418035791555, value = raju
1 row(s) in 0.0080 seconds

Java API를 사용하여 데이터 읽기

HBase 테이블에서 데이터를 읽으려면 get()HTable 클래스의 메서드. 이 메서드에는Get수업. HBase 테이블에서 데이터를 검색하려면 아래 단계를 따르십시오.

1 단계 : 구성 클래스 인스턴스화

Configuration클래스는 HBase 구성 파일을 객체에 추가합니다. 다음을 사용하여 구성 개체를 만들 수 있습니다.create() 의 방법 HbaseConfiguration 아래와 같이 클래스.

Configuration conf = HbaseConfiguration.create();

2 단계 : HTable 클래스 인스턴스화

라는 수업이 있습니다. HTable, HBase의 Table 구현입니다. 이 클래스는 단일 HBase 테이블과 통신하는 데 사용됩니다. 이 클래스를 인스턴스화하는 동안 구성 개체와 테이블 이름을 매개 변수로 받아들입니다. 아래와 같이 HTable 클래스를 인스턴스화 할 수 있습니다.

HTable hTable = new HTable(conf, tableName);

3 단계 : Get 클래스 인스턴스화

다음을 사용하여 HBase 테이블에서 데이터를 검색 할 수 있습니다. get() 의 방법 HTable수업. 이 메서드는 주어진 행에서 셀을 추출합니다. 그것은Get매개 변수로 클래스 개체. 아래와 같이 만듭니다.

Get get = new Get(toBytes("row1"));

4 단계 : 데이터 읽기

데이터를 검색하는 동안 ID로 단일 행을 가져 오거나 행 ID 세트로 행 세트를 가져 오거나 전체 테이블 또는 행의 하위 집합을 스캔 할 수 있습니다.

add 메서드 변형을 사용하여 HBase 테이블 데이터를 검색 할 수 있습니다. Get 수업.

특정 column family에서 특정 열을 가져 오려면 다음 방법을 사용하십시오.

get.addFamily(personal)

특정 column family에서 모든 열을 가져 오려면 다음 방법을 사용하십시오.

get.addColumn(personal, name)

5 단계 : 결과 얻기

통과하여 결과를 얻으십시오. Get 클래스 인스턴스의 get 메소드에 HTable수업. 이 메서드는Result요청 된 결과를 보유하는 클래스 객체. 아래에 주어진 사용법은get() 방법.

Result result = table.get(g);

6 단계 : 결과 인스턴스에서 값 읽기

그만큼 Result 클래스는 getValue()인스턴스에서 값을 읽는 메서드. 아래 표시된대로 사용하여Result 예.

byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));
byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));

다음은 HBase 테이블에서 값을 읽는 완전한 프로그램입니다.

import java.io.IOException;

import org.apache.hadoop.conf.Configuration;

import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.client.Get;
import org.apache.hadoop.hbase.client.HTable;
import org.apache.hadoop.hbase.client.Result;
import org.apache.hadoop.hbase.util.Bytes;

public class RetriveData{

   public static void main(String[] args) throws IOException, Exception{
   
      // Instantiating Configuration class
      Configuration config = HBaseConfiguration.create();

      // Instantiating HTable class
      HTable table = new HTable(config, "emp");

      // Instantiating Get class
      Get g = new Get(Bytes.toBytes("row1"));

      // Reading the data
      Result result = table.get(g);

      // Reading values from Result class object
      byte [] value = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("name"));

      byte [] value1 = result.getValue(Bytes.toBytes("personal"),Bytes.toBytes("city"));

      // Printing the values
      String name = Bytes.toString(value);
      String city = Bytes.toString(value1);
      
      System.out.println("name: " + name + " city: " + city);
   }
}

위의 프로그램을 아래와 같이 컴파일하고 실행합니다.

$javac RetriveData.java
$java RetriveData

다음은 출력이어야합니다.

name: Raju city: Delhi