IMS DB-보조 인덱싱

Secondary Indexing은 전체 연결 키를 사용하지 않고 데이터베이스에 액세스하거나 시퀀스 기본 필드를 사용하지 않으려는 경우에 사용됩니다.

인덱스 포인터 세그먼트

DL / I는 인덱스 된 데이터베이스의 세그먼트에 대한 포인터를 별도의 데이터베이스에 저장합니다. 인덱스 포인터 세그먼트는 유일한 보조 인덱스 유형입니다. 두 부분으로 구성되어 있습니다-

  • 접두사 요소
  • 데이터 요소

접두사 요소

인덱스 포인터 세그먼트의 접두어 부분에는 인덱스 대상 세그먼트에 대한 포인터가 포함됩니다. 인덱스 대상 세그먼트는 보조 인덱스를 사용하여 액세스 할 수있는 세그먼트입니다.

데이터 요소

데이터 요소에는 색인이 작성되는 색인화 된 데이터베이스의 세그먼트에있는 키 값이 포함됩니다. 이를 인덱스 소스 세그먼트라고도합니다.

Secondary Indexing에 대해 주목해야 할 핵심 사항은 다음과 같습니다.

  • 인덱스 소스 세그먼트와 대상 소스 세그먼트는 동일하지 않아도됩니다.

  • 보조 인덱스를 설정하면 DL / I가 자동으로 유지 관리합니다.

  • DBA는 다중 액세스 경로에 따라 많은 보조 인덱스를 정의합니다. 이러한 보조 인덱스는 별도의 인덱스 데이터베이스에 저장됩니다.

  • DL / I에 추가 처리 오버 헤드를 부과하므로 더 많은 보조 인덱스를 생성해서는 안됩니다.

보조 키

주목할 점-

  • 보조 인덱스가 작성되는 인덱스 소스 세그먼트의 필드를 보조 키라고합니다.

  • 모든 필드를 보조 키로 사용할 수 있습니다. 세그먼트 시퀀스 필드 일 필요는 없습니다.

  • 보조 키는 인덱스 소스 세그먼트 내의 단일 필드 조합 일 수 있습니다.

  • 보조 키 값은 고유하지 않아도됩니다.

2 차 데이터 구조

주목할 점-

  • 보조 인덱스를 만들 때 데이터베이스의 명백한 계층 구조도 변경됩니다.

  • 인덱스 대상 세그먼트는 명백한 루트 세그먼트가됩니다. 다음 이미지에 표시된 것처럼 엔지니어링 세그먼트는 루트 세그먼트가 아니더라도 루트 세그먼트가됩니다.

  • 보조 인덱스로 인한 데이터베이스 구조 재 배열을 보조 데이터 구조라고합니다.

  • 보조 데이터 구조는 디스크에있는 기본 물리적 데이터베이스 구조를 변경하지 않습니다. 응용 프로그램 앞에서 데이터베이스 구조를 변경하는 방법 일뿐입니다.

독립 AND 연산자

주목할 점-

  • AND (* 또는 &) 연산자가 보조 인덱스와 함께 사용되는 경우이를 종속 AND 연산자라고합니다.

  • 독립 AND (#)를 사용하면 종속 AND로는 불가능한 자격을 지정할 수 있습니다.

  • 이 연산자는 인덱스 소스 세그먼트가 인덱스 대상 세그먼트에 종속 된 보조 인덱스에만 사용할 수 있습니다.

  • 두 개 이상의 종속 소스 세그먼트의 필드를 기반으로 대상 세그먼트의 발생이 처리되도록 지정하기 위해 독립 AND로 SSA를 코딩 할 수 있습니다.

01 ITEM-SELECTION-SSA.
   05 FILLER           PIC X(8).
   05 FILLER           PIC X(1) VALUE '('.
   05 FILLER           PIC X(10).
   05 SSA-KEY-1        PIC X(8).
   05 FILLER           PIC X   VALUE '#'.
   05 FILLER           PIC X(10).
   05 SSA-KEY-2        PIC X(8).
   05 FILLER           PIC X   VALUE ')'.

희소 시퀀싱

주목할 점-

  • Sparse Sequencing은 Sparse Indexing이라고도합니다. 보조 인덱스 데이터베이스에서 스파 스 시퀀싱을 사용하여 인덱스에서 일부 인덱스 소스 세그먼트를 제거 할 수 있습니다.

  • 성능 향상을 위해 희소 시퀀싱이 사용됩니다. 인덱스 소스 세그먼트가 사용되지 않는 경우이를 제거 할 수 있습니다.

  • DL / I는 억제 값이나 억제 루틴 또는 둘 다를 사용하여 세그먼트를 인덱싱해야하는지 여부를 결정합니다.

  • 인덱스 소스 세그먼트의 시퀀스 필드 값이 억제 값과 일치하면 인덱스 관계가 설정되지 않습니다.

  • 억제 루틴은 세그먼트를 평가하고 색인화해야하는지 여부를 결정하는 사용자 작성 프로그램입니다.

  • 희소 인덱싱이 사용되는 경우 해당 기능은 DL / I에서 처리됩니다. 우리는 응용 프로그램에서 그것에 대한 특별한 조항을 만들 필요가 없습니다.

DBDGEN 요구 사항

이전 모듈에서 설명했듯이 DBDGEN은 DBD를 만드는 데 사용됩니다. 보조 인덱스를 만들 때 두 개의 데이터베이스가 관련됩니다. DBA는 인덱싱 된 데이터베이스와 보조 인덱싱 된 데이터베이스 간의 관계를 만들기 위해 두 개의 DBDGEN을 사용하여 두 개의 DBD를 만들어야합니다.

PSBGEN 요구 사항

데이터베이스에 대한 보조 인덱스를 생성 한 후 DBA는 PSB를 생성해야합니다. 프로그램에 대한 PSBGEN은 PSB 매크로의 PROCSEQ 매개 변수에서 데이터베이스에 대한 적절한 처리 순서를 지정합니다. PROCSEQ 매개 변수의 경우 DBA는 보조 인덱스 데이터베이스의 DBD 이름을 코딩합니다.