HCatalog-인덱스

인덱스 생성

인덱스는 테이블의 특정 열에 대한 포인터 일뿐입니다. 인덱스를 만드는 것은 테이블의 특정 열에 대한 포인터를 만드는 것을 의미합니다. 구문은 다음과 같습니다.

CREATE INDEX index_name
ON TABLE base_table_name (col_name, ...)
AS 'index.handler.class.name'
[WITH DEFERRED REBUILD]
[IDXPROPERTIES (property_name = property_value, ...)]
[IN TABLE index_table_name]
[PARTITIONED BY (col_name, ...)][
   [ ROW FORMAT ...] STORED AS ...
   | STORED BY ...
]
[LOCATION hdfs_path]
[TBLPROPERTIES (...)]

인덱스의 개념을 이해하기 위해 예를 들어 보겠습니다. 같은 것을 사용하십시오employee Id, Name, Salary, Designation 및 Dept 필드와 함께 이전에 사용한 테이블입니다. index_salarysalary 의 열 employee 표.

다음 쿼리는 인덱스를 생성합니다-

./hcat –e "CREATE INDEX inedx_salary ON TABLE employee(salary)
AS 'org.apache.hadoop.hive.ql.index.compact.CompactIndexHandler';"

그것은에 대한 포인터입니다 salary기둥. 열이 수정되면 인덱스 값을 사용하여 변경 사항이 저장됩니다.

인덱스 삭제

다음 구문은 인덱스를 삭제하는 데 사용됩니다-

DROP INDEX <index_name> ON <table_name>

다음 쿼리는 index_salary 인덱스를 삭제합니다-

./hcat –e "DROP INDEX index_salary ON employee;"