SAP HANA 관리자-테이블 파티션

파티셔닝을 사용하면 여러 호스트 시스템에서 열 저장소 테이블을 더 작은 테이블로 분할 할 수 있습니다. 파티셔닝을 사용하여 테이블을 더 작고 관리하기 쉬운 부분으로 나눌 수도 있습니다. 분할은 DML SQL 문을 사용하여 수행 할 수 있습니다.

테이블이 분할되면 각 부분에 대해 서로 다른 행 세트가 포함되며 분할은 해시 분할, 단일 레벨 또는 다중 레벨 분할과 같은 다른 알고리즘을 기반으로 수행 될 수 있습니다.

다음은 테이블 파티셔닝 사용의 장점입니다-

분할 정리

특정 파티션에서 쿼리를 분석 할 수 있는지 확인할 수 있습니다. 이 방법을 사용하면 시스템의 부하를 줄여 응답 시간을 개선 할 수 있습니다.

Example− 연도를 기준으로 테이블을 분할하면 특정 연도의 데이터를 분석하기위한 쿼리가 실행됩니다. 특정 파티션을 사용할 수 있으므로 쿼리 성능이 향상됩니다.

부하 분산

여러 호스트에서 개별 파티션을 나눌 수 있으므로 쿼리가 단일 서버에서 처리되지 않으므로 테이블 파티션을 호스팅하는 모든 서버에서로드 밸런싱이 향상됩니다.

크기 제한

열 저장소 테이블에서 입력 할 수있는 최대 행 수는 약 20 억입니다. 열 테이블의 행을 여러 파티션에 분산하여이를 극복 할 수 있으므로 각 파티션에 대해 크기 제한이 20 억으로 증가합니다.

개선 된 델타 병합 작업

델타 병합 중에 데이터가 일부 파티션에 대해서만 수정되는 경우 델타 병합에서 더 적은 파티션을 병합해야합니다.

쿼리 병렬 처리

파티션을 사용하면 여러 쿼리를 병렬로 실행할 수 있으므로 응답 시간이 향상됩니다.

이제 파티셔닝 유형에 대해 논의하겠습니다.

단일 레벨 파티셔닝

SAP HANA 시스템에서 사용할 수있는 다양한 유형의 단일 레벨 파티셔닝이 있습니다.

  • 해시 파티셔닝
  • 라운드 로빈 분할
  • 범위 분할

해시 파티셔닝에서는로드 밸런싱을 수행하기 위해 행이 균등하게 분산됩니다. 이 파티셔닝 유형의 테이블 콘텐츠에 대한 자세한 정보는 필요하지 않습니다.

해시 파티셔닝과 비교하여 라운드 로빈 파티셔닝에서는 행이 각 파티션에 균등하게 분배되고 새 행이 각 파티션에 균등하게 할당됩니다.

라운드 로빈을 사용하여 테이블의 4 개 파티션을 생성하려면 다음 SQL 쿼리를 사용할 수 있습니다. 기본 키를 정의하지 않아야합니다.

CREATE COLUMN TABLE TABLENAME (a INT, b INT, c INT) 
PARTITION BY ROUNDROBIN PARTITIONS 4

이 명령은 테이블의 4 개의 파티션을 생성합니다.

CREATE COLUMN TABLE Table_Name (a INT, b INT, c INT, PRIMARY KEY (a,b)) 
PARTITION BY HASH (a, b) PARTITIONS 4

열에 4 개의 파티션이 생성됩니다. ab, 하나 이상의 열을 지정해야합니다.

범위 분할

범위 분할에서는 특정 값에 대한 전용 파티션을 만들고 열 분할을위한 테이블 내용에 대한 심층적 인 지식이 있어야합니다.

Example − 매월마다 하나의 파티션 생성.

CREATE COLUMN TABLE TABLE_NAME (a INT, b INT, c INT, PRIMARY KEY (a,b)) 
PARTITION BY RANGE (a) 
(PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20, 
PARTITION VALUE = 50, PARTITION  OTHERS)

이것은 4 개 파티션 분할 범위 생성되며, 1 내지 10, 2 10 ~ 20의 3 번째 값 (50), 4 번째 다른 값.

다단계 분할

다단계 분할에서 HASH 및 RANGE 단일 수준 분할의 한계를 극복하여 키 열을 분할 열로 사용할 수 있습니다. 다단계 분할을 사용하면 기본 키가 아닌 열을 분할 할 수 있습니다. 다단계 분할의 가장 일반적인 유형은 다음과 같습니다.HASH-Range Partitioning.

Hash-Range 다중 레벨 파티셔닝에서는 첫 번째 레벨에서 Hash 파티셔닝을 구현하여로드 밸런싱을 구현하고 두 번째 레벨에서 범위 파티셔닝을 구현하여 시간 기반 파티셔닝을 구현합니다.

CREATE COLUMN TABLE Table_name (a INT, b INT, c INT, PRIMARY KEY (a,b))
PARTITION BY HASH (a, b) PARTITIONS 4,
RANGE (c) (PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20)

첫 번째 수준에서 해시 파티셔닝을 사용하는 대신 라운드 로빈 파티셔닝을 사용할 수도 있습니다. Round Robin-Range multilevel partitioning.

CREATE COLUMN TABLE Table_name (a INT, b INT, c INT) 
PARTITION BY ROUNDROBIN PARTITIONS 4,
RANGE (c) (PARTITION 1 <= VALUES < 10, PARTITION 10 <= VALUES < 20)