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