Un model de date ierarhic este un model de date care utilizează o reprezentare a bazei de date sub forma unei structuri arborescente ( ierarhice ) constând din obiecte ( date ) de diferite niveluri.
Există legături între obiecte, fiecare obiect poate include mai multe obiecte de un nivel inferior. Astfel de obiecte sunt în relație cu un strămoș (un obiect mai aproape de rădăcină) cu un copil (un obiect de un nivel inferior), în timp ce este posibil ca obiectul strămoș să aibă mai mulți copii, în timp ce obiectul copil trebuie să aibă un singur strămoș. Obiectele care au un strămoș comun se numesc gemeni (în programare, în raport cu structura datelor, un arbore se numește frați).
Bazele de date ierarhice sunt printre cele mai vechi și au fost primele sisteme de gestionare a bazelor de date mainframe . Dezvoltat în anii 1950 și 1960, de exemplu, de către IBM Information Management System (IMS) [1] .
De exemplu, dacă o bază de date ierarhică conține informații despre clienți și comenzile acestora, atunci ar exista un obiect client (părinte) și un obiect comandă (copil). Obiectul client va avea indicii de la fiecare client către locația fizică a comenzilor clientului în obiectul comandă .
În acest model , interogarea în jos a ierarhiei este simplă (de exemplu, ce comenzi aparțin acestui client). Cu toate acestea, o interogare direcționată în sus în ierarhie este mai complexă (de exemplu, care client a plasat această comandă). De asemenea, este dificil să se reprezinte date non-ierarhice atunci când se utilizează acest model.
O bază de date ierarhică este un sistem de fișiere format dintr-un director rădăcină care are o ierarhie de subdirectoare și fișiere.
Principalele unități informaționale din modelul ierarhic de date sunt segmentul și câmpul. Un câmp de date este definit ca cea mai mică unitate indivizibilă de date disponibilă unui utilizator. Pentru un segment, sunt definite un tip de segment și o instanță de segment. O instanță de segment este formată din valori specifice câmpului de date. Un tip de segment este o colecție numită a tipurilor sale de câmpuri de date.
La fel ca și rețeaua, modelul ierarhic de date se bazează pe forma grafică a construcției datelor, iar la nivel conceptual, este doar un caz special al modelului de date în rețea. Într-un model de date ierarhic, partea de sus a graficului corespunde unui tip de segment sau doar unui segment, iar arcelor, tipurilor de relații părinte-copil. În structurile ierarhice, un segment descendent trebuie să aibă exact un părinte.
Modelul ierarhic este un grafic nedirecționat conex al unei structuri arborescente care combină segmente. O bază de date ierarhică constă dintr-un set ordonat de arbori.
În cadrul modelului ierarhic se disting instrumentele de limbaj de descriere a datelor (DDL) și instrumentele de manipulare a datelor (DML). Fiecare bază de date fizică este descrisă de un set de operatori care determină atât structura sa logică, cât și structura de stocare a bazei de date. În acest caz, metoda de acces determină modul în care sunt legate înregistrările fizice.
Sunt definite următoarele metode de acces:
Pe lângă specificarea numelui bazei de date și a metodei de acces, descrierile trebuie să conțină definiții ale tipurilor de segmente care alcătuiesc baza de date, în conformitate cu ierarhia, începând de la segmentul rădăcină. Fiecare bază de date fizică conține un singur fragment rădăcină, dar un sistem poate avea mai multe baze de date fizice.
Operatorii de manipulare a datelor includ operatorii de căutare a datelor, operatorii de căutare a datelor cu posibilitate de modificare și operatorii de modificare a datelor. Setul de operațiuni de manipulare a datelor dintr-o bază de date ierarhică este mic, dar destul de suficient.
Exemple de operatori tipici de căutare a datelor cu posibilitatea de modificare:
Exemple de operatori tipici de modificare pentru date organizate ierarhic care sunt executate după executarea unuia dintre operatorii din a doua grupă (căutare de date cu posibilitate de modificare):
Într-un model ierarhic, integritatea referenţială este menţinută automat între strămoşi şi descendenţi. Regula de bază: niciun copil nu poate exista fără părintele său.
Exemple de baze de date cu model ierarhic sunt [2] :
Convertirea unui model conceptual într-o structură de date ierarhică este în multe privințe similară cu conversia acestuia într-un model de rețea , dar are și unele diferențe datorită faptului că un model ierarhic necesită organizarea tuturor datelor sub forma unui arbore.
Transformarea unei relații unu-la-mulți dintre un strămoș și un descendent este aproape automată dacă descendentul are un singur strămoș, iar acest lucru se întâmplă după cum urmează. Fiecare obiect cu atributele sale care participă la o astfel de relație devine un segment logic. Se stabilește o relație unu-la-mulți între două segmente logice. Segmentul de pe partea „mulți” devine un copil, iar segmentul de pe partea „unui” devine un strămoș.
Situația devine mult mai complicată dacă descendentul are în legătură nu unul, ci doi sau mai mulți strămoși. Întrucât o astfel de situație este imposibilă pentru un model ierarhic, structura de date reflectată are nevoie de transformări, care se reduc la înlocuirea unui arbore, de exemplu, cu doi (dacă există doi strămoși). Ca urmare a unei astfel de transformări, redundanța apare în baza de date, deoarece singura cale posibilă de ieșire din această situație este duplicarea datelor.
Bază de date | |
---|---|
Concepte |
|
Obiecte |
|
Chei | |
SQL |
|
Componente |