IMS DB - pobieranie danych
Różne metody pobierania danych używane w wywołaniach IMS DL / I są następujące:
- GU Call
- GN Call
- Korzystanie z kodów poleceń
- Wielokrotne przetwarzanie
Rozważmy następującą strukturę bazy danych IMS, aby zrozumieć wywołania funkcji pobierania danych -
GU Call
Podstawy wywołania GU są następujące -
Wywołanie GU jest znane jako połączenie Get Unique. Służy do losowego przetwarzania.
Jeśli aplikacja nie aktualizuje regularnie bazy danych lub jeśli liczba aktualizacji bazy danych jest mniejsza, używamy przetwarzania losowego.
Wywołanie GU służy do umieszczenia wskaźnika w określonej pozycji w celu dalszego sekwencyjnego wyszukiwania.
Wywołania GU są niezależne od pozycji wskaźnika ustalonej przez poprzednie wywołania.
Przetwarzanie wywołań GU jest oparte na unikalnych polach kluczy dostarczonych w instrukcji wywołania.
Jeśli dostarczymy pole klucza, które nie jest unikalne, DL / I zwraca wystąpienie pierwszego segmentu pola klucza.
CALL 'CBLTDLI' USING DLI-GU
PCB-NAME
IO-AREA
LIBRARY-SSA
BOOKS-SSA
ENGINEERING-SSA
IT-SSA
Powyższy przykład pokazuje, że wysyłamy wywołanie GU, udostępniając pełny zestaw kwalifikowanych SSA. Obejmuje wszystkie kluczowe pola, począwszy od poziomu głównego do wystąpienia segmentu, który chcemy pobrać.
Uwagi dotyczące wywołań GU
Jeśli w zgłoszeniu nie podamy pełnego zestawu kwalifikowanych SSA, wówczas DL / I działa w następujący sposób -
Kiedy używamy niekwalifikowanego SSA w wywołaniu GU, DL / I uzyskuje dostęp do pierwszego wystąpienia segmentu w bazie danych, które spełnia określone przez Ciebie kryteria.
Kiedy wywołujemy GU bez żadnych SSA, DL / I zwraca pierwsze wystąpienie segmentu głównego w bazie danych.
Jeżeli w zaproszeniu nie wymieniono niektórych SSA na poziomach pośrednich, wówczas DL / I wykorzystuje ustaloną pozycję lub wartość domyślną niekwalifikowanego SSA dla segmentu.
Kody stanu
W poniższej tabeli przedstawiono odpowiednie kody stanu po wywołaniu GU -
S.Nr | Kod stanu i opis |
---|---|
1 | Spaces Udane połączenie |
2 | GE DL / I nie udało się znaleźć segmentu spełniającego kryteria określone w wezwaniu |
GN Call
Podstawy wywołania GN są następujące -
Wywołanie GN jest znane jako wywołanie Get Next. Służy do podstawowego przetwarzania sekwencyjnego.
Początkowa pozycja wskaźnika w bazie danych znajduje się przed segmentem głównym pierwszego rekordu bazy danych.
Pozycja wskaźnika bazy danych znajduje się przed następnym wystąpieniem segmentu w sekwencji, po udanym wywołaniu GN.
Wywołanie GN rozpoczyna się w bazie danych od pozycji ustalonej przez poprzednie wywołanie.
Jeśli wywołanie GN jest niekwalifikowane, zwraca następne wystąpienie segmentu w bazie danych niezależnie od jego typu, w kolejności hierarchicznej.
Jeśli wywołanie GN zawiera SSA, wówczas DL / I pobiera tylko segmenty, które spełniają wymagania wszystkich określonych SSA.
CALL 'CBLTDLI' USING DLI-GN
PCB-NAME
IO-AREA
BOOKS-SSA
Powyższy przykład pokazuje, że wysyłamy wywołanie GN, podając pozycję początkową do sekwencyjnego odczytu rekordów. Pobiera pierwsze wystąpienie segmentu KSIĄŻKI.
Kody stanu
W poniższej tabeli przedstawiono odpowiednie kody stanu po wywołaniu GN -
S.Nr | Kod stanu i opis |
---|---|
1 | Spaces Udane połączenie |
2 | GE DL / I nie udało się znaleźć segmentu spełniającego kryteria określone w wezwaniu. |
3 | GA Niekwalifikowane wywołanie GN przechodzi o jeden poziom w górę w hierarchii bazy danych, aby pobrać segment. |
4 | GB Osiągnięto koniec bazy danych i nie znaleziono segmentu. |
GK Niekwalifikowane wywołanie GN próbuje pobrać segment określonego typu, inny niż ten właśnie pobrany, ale pozostaje na tym samym poziomie hierarchii. |
Kody poleceń
Kody poleceń są używane z wywołaniami w celu pobrania wystąpienia segmentu. Poniżej omówiono różne kody poleceń używane w wywołaniach.
Kod polecenia F.
Punkty do zapamiętania -
Gdy kod polecenia F jest określony w wywołaniu, wywołanie przetwarza pierwsze wystąpienie segmentu.
Kody poleceń F mogą być używane, gdy chcemy przetwarzać sekwencyjnie i mogą być używane z wywołaniami GN i wywołaniami GNP.
Jeśli określimy kod polecenia F z wywołaniem GU, nie ma to żadnego znaczenia, ponieważ wywołania GU domyślnie pobierają wystąpienie pierwszego segmentu.
Kod polecenia L.
Punkty do zapamiętania -
Gdy kod polecenia L jest określony w wywołaniu, wywołanie przetwarza ostatnie wystąpienie segmentu.
Kody poleceń L mogą być używane, gdy chcemy przetwarzać sekwencyjnie i mogą być używane z wywołaniami GN i wywołaniami GNP.
Kod polecenia D.
Punkty do zapamiętania -
Kod polecenia D jest używany do pobierania więcej niż jednego wystąpienia segmentu przy użyciu tylko jednego wywołania.
Zwykle DL / I działa na najniższym segmencie poziomu określonym w SSA, ale w wielu przypadkach potrzebujemy również danych z innych poziomów. W takich przypadkach możemy użyć kodu polecenia D.
Kod polecenia D ułatwia pobieranie całej ścieżki segmentów.
Kod polecenia C.
Punkty do zapamiętania -
Kod polecenia C służy do łączenia kluczy.
Korzystanie z operatorów relacyjnych jest nieco skomplikowane, ponieważ musimy określić nazwę pola, operator relacyjny i wartość wyszukiwania. Zamiast tego możemy użyć kodu polecenia C, aby dostarczyć połączony klucz.
Poniższy przykład pokazuje użycie kodu polecenia C -
01 LOCATION-SSA.
05 FILLER PIC X(11) VALUE ‘INLOCSEG*C(‘.
05 LIBRARY-SSA PIC X(5).
05 BOOKS-SSA PIC X(4).
05 ENGINEERING-SSA PIC X(6).
05 IT-SSA PIC X(3)
05 FILLER PIC X VALUE ‘)’.
CALL 'CBLTDLI' USING DLI-GU
PCB-NAME
IO-AREA
LOCATION-SSA
Kod polecenia P.
Punkty do zapamiętania -
Kiedy wykonujemy wywołanie GU lub GN, DL / I ustanawia swoje pochodzenie na najniższym pobieranym segmencie.
Jeśli włączymy kod polecenia P, wówczas DL / I ustanawia swoje pochodzenie na segmencie wyższego poziomu w ścieżce hierarchicznej.
Kod polecenia U.
Punkty do zapamiętania -
Gdy kod polecenia U jest określony w niekwalifikowanym SSA w wywołaniu GN, DL / I ogranicza wyszukiwanie segmentu.
Kod polecenia U jest ignorowany, jeśli jest używany z kwalifikowanym SSA.
Kod polecenia V.
Punkty do zapamiętania -
Kod polecenia V działa podobnie do kodu polecenia U, ale ogranicza wyszukiwanie segmentu na określonym poziomie i na wszystkich poziomach powyżej hierarchii.
Kod polecenia V jest ignorowany, gdy jest używany z kwalifikowanym SSA.
Q Command Code
Punkty do zapamiętania -
Kod polecenia Q jest używany do umieszczania w kolejce lub rezerwacji segmentu do wyłącznego użytku programu aplikacji.
Kod polecenia Q jest używany w środowisku interaktywnym, w którym inny program może dokonać zmiany w segmencie.
Wielokrotne przetwarzanie
Program może mieć wiele pozycji w bazie danych IMS, co jest znane jako przetwarzanie wielokrotne. Wielokrotne przetwarzanie można przeprowadzić na dwa sposoby -
- Wiele PCB
- Wielokrotne pozycjonowanie
Wiele PCB
Dla jednej bazy danych można zdefiniować wiele PCB. Jeśli istnieje wiele płytek drukowanych, program aplikacji może mieć różne widoki. Ta metoda implementacji wielokrotnego przetwarzania jest nieefektywna ze względu na narzuty narzucone przez dodatkowe PCB.
Wielokrotne pozycjonowanie
Program może utrzymywać wiele pozycji w bazie danych za pomocą jednej płytki PCB. Osiąga się to poprzez utrzymanie odrębnej pozycji dla każdej ścieżki hierarchicznej. Wielokrotne pozycjonowanie służy do uzyskiwania dostępu do segmentów dwóch lub więcej typów sekwencyjnie w tym samym czasie.