IMS DB - Pengindeksan Sekunder
Pengindeksan Sekunder digunakan saat kita ingin mengakses database tanpa menggunakan kunci gabungan lengkap atau saat kita tidak ingin menggunakan bidang utama urutan.
Segmen Penunjuk Indeks
DL / I menyimpan penunjuk ke segmen database yang diindeks dalam database terpisah. Segmen penunjuk indeks adalah satu-satunya jenis indeks sekunder. Ini terdiri dari dua bagian -
- Elemen Awalan
- Elemen Data
Elemen Awalan
Bagian awalan segmen penunjuk indeks berisi penunjuk ke Segmen Target Indeks. Segmen sasaran indeks adalah segmen yang dapat diakses dengan menggunakan indeks sekunder.
Elemen Data
Elemen data berisi nilai kunci dari segmen dalam database yang diindeks tempat indeks dibuat. Ini juga dikenal sebagai segmen sumber indeks.
Berikut adalah poin-poin penting yang perlu diperhatikan tentang Pengindeksan Sekunder -
Segmen sumber indeks dan segmen sumber sasaran tidak harus sama.
Saat kami menyiapkan indeks sekunder, secara otomatis dikelola oleh DL / I.
DBA mendefinisikan banyak indeks sekunder sesuai dengan beberapa jalur akses. Indeks sekunder ini disimpan dalam database indeks terpisah.
Kita tidak boleh membuat lebih banyak indeks sekunder, karena mereka memberlakukan overhead pemrosesan tambahan pada DL / I.
Kunci Sekunder
Poin yang perlu diperhatikan -
Bidang di segmen sumber indeks tempat pembuatan indeks sekunder disebut sebagai kunci sekunder.
Bidang apa pun dapat digunakan sebagai kunci sekunder. Ini tidak harus berupa bidang urutan segmen.
Kunci sekunder dapat berupa kombinasi dari satu kolom dalam segmen sumber indeks.
Nilai kunci sekunder tidak harus unik.
Struktur Data Sekunder
Poin yang perlu diperhatikan -
Ketika kita membangun indeks sekunder, struktur hierarki database yang terlihat juga berubah.
Segmen sasaran indeks menjadi segmen akar yang nyata. Seperti yang ditunjukkan pada gambar berikut, segmen Teknik menjadi segmen akar, meskipun itu bukan segmen akar.
Penataan kembali struktur database yang disebabkan oleh indeks sekunder dikenal dengan struktur data sekunder.
Struktur data sekunder tidak membuat perubahan apa pun pada struktur database fisik utama yang ada di disk. Ini hanyalah cara untuk mengubah struktur database di depan program aplikasi.
Independen DAN Operator
Poin yang perlu diperhatikan -
Jika operator AND (* atau &) digunakan dengan indeks sekunder, ini dikenal sebagai operator AND dependen.
AND (#) independen memungkinkan kita untuk menentukan kualifikasi yang tidak mungkin dilakukan dengan dependen AND.
Operator ini hanya dapat digunakan untuk indeks sekunder di mana segmen sumber indeks bergantung pada segmen sasaran indeks.
Kita dapat membuat kode SSA dengan AND independen untuk menentukan bahwa kemunculan segmen target diproses berdasarkan bidang di dua atau lebih segmen sumber dependen.
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 ')'.
Pengurutan Renggang
Poin yang perlu diperhatikan -
Urutan renggang juga dikenal sebagai Pengindeksan Renggang. Kami dapat menghapus beberapa segmen sumber indeks dari indeks menggunakan pengurutan jarang dengan database indeks sekunder.
Urutan renggang digunakan untuk meningkatkan kinerja. Ketika beberapa kemunculan segmen sumber indeks tidak digunakan, kami dapat menghapusnya.
DL / I menggunakan nilai penekanan atau rutinitas penekanan atau keduanya untuk menentukan apakah segmen harus diindeks.
Jika nilai bidang urutan di segmen sumber indeks cocok dengan nilai penekanan, maka tidak ada hubungan indeks yang dibuat.
Rutin penekanan adalah program yang ditulis pengguna yang mengevaluasi segmen dan menentukan apakah harus diindeks atau tidak.
Saat pengindeksan jarang digunakan, fungsinya ditangani oleh DL / I. Kita tidak perlu membuat ketentuan khusus untuk itu dalam program aplikasi.
Persyaratan DBDGEN
Sebagaimana dibahas dalam modul sebelumnya, DBDGEN digunakan untuk membuat DBD. Saat kami membuat indeks sekunder, dua database terlibat. DBA perlu membuat dua DBD menggunakan dua DBDGEN untuk membuat hubungan antara database terindeks dan database terindeks sekunder.
Persyaratan PSBGEN
Setelah membuat indeks sekunder untuk database, DBA perlu membuat PSB. PSBGEN untuk program menentukan urutan pemrosesan yang tepat untuk database pada parameter PROCSEQ dari makro PSB. Untuk parameter PROCSEQ, DBA mengkodekan nama DBD untuk database indeks sekunder.