Relációsadatbázis-kezelő rendszer

A relációsadatbázis-kezelő rendszer (angol rövidítéséből: RDBMS) egy olyan adatbázis-kezelő rendszer, amelynek logikai adatbázisát szoftverkomponensei kizárólag a relációs adatmodellek elvén épülnek fel, illetve kérdezhetőek le. Más, divatos szavakkal kifejezve: az RDBMS kizárólag az relációs adatmodell alapú megközelítést támogatja. Amennyiben más adatmodell is kiszolgálható ilyen rendszerrel, úgy a kapcsolódó adatmodell függvényében objektumrelációs, illetve deduktív relációs adatbázisról beszélhetünk. A relációsadatbázis-kezelő rendszerek szabványos adathozzáférési és adatdefiníciós nyelve az SQL.

Jelenleg elérhető termékek szerkesztés

Gyártó (forgalmazó) és terméknév szerint (2006-os állapot):

Nyílt forráskódban elérhető adatbázis-kezelő rendszerek (2006-os állapot):

Kiegészítés szerkesztés

Codd szabályai szerkesztés

Edgar F. Codd (akit Tednek becéztek) 12 szabály néven elhíresült 13 megállapítása a relációsadatbázis-kezelő rendszerek legfontosabb ismérveit rögzítik. Ted Codd 1985-ben a Computerworld c. újság október 14-i és 21-i számában, két részletben foglalta össze a relációsadatbázis-kezelő rendszerek legfontosabb tulajdonságait, adottságait és szükségszerűségeit, amelyet azóta számosan idéztek és dolgoztak fel; tananyaggá lett.

Az alábbiakban Chris J. Date tolmácsolásában ismerhetjük meg e szabályokat:

A 0. szabály szerkesztés

Ahhoz, hogy egy rendszer relációsnak, adatbázisnak, és kezelő rendszernek legyen nevezhető, elfogadható – a rendszernek a relációkkal foglalkozó adottságait (kizárólag) az adatbázis kezelésére kell használnia.

1. Az egységes megjelenésű információ szabálya szerkesztés

Ez a szabály egyszerűen csak annyit ír elő, hogy az adatbázisban szereplő összes információt egy, és csak egy megadott formában lehet ábrázolni, nevezetesen a sorokba szedett táblázatokon belül egy-egy oszlop pozícióban. (vízszintes és függőleges koordináta-rendszerben – a ford.)

2. Garantált lokalizálhatóság szabálya szerkesztés

Ez a szabály lényegében az elsődleges kulcs alapkövetelményének megfogalmazása másképpen. Azt mondja ki, hogy az adatbázisban minden egyes skaláris értékre logikailag úgy kell hivatkozni, hogy megadjuk az azt tartalmazó táblázat és az oszlop nevét, valamint a megfelelő sor (azt tartalmazó sor) elsődleges kulcsának az értékét.

3. A NULL értékek egységes kezelése szerkesztés

Az adatbázis-kezelő rendszernek (DBMS) olyan módszerrel kell támogatnia a „hiányzó és nem felhasználható információt” amely egységes, és eltér az összes „rendes” érték kezelésétől (például numerikus értékek esetében, „nullától vagy más számtól különböző”-ként), továbbá független az adattípustól. Ebbe az is beletartozik, hogy ezeknek a reprezentációknak a kezelését a szoftvernek módszeresen kell végeznie.

4. A relációs modell alapján aktív online katalógust kell üzemben tartani szerkesztés

A rendszernek támogatnia kell egy online, beépített katalógust, amely a szokásos lekérdező nyelvet használó feljogosított felhasználók előtt nyitva áll.

5. A teljes körű „adatnyelv” szabálya szerkesztés

A rendszernek legalább egy olyan relációs nyelvet kell támogatnia, amelynek

  • (a) lineáris a szintaxisa,
  • (b) interaktívan és alkalmazási programokon belül is lehet használni, továbbá
  • (c) támogatja az adat definiáló műveleteket (beleértve az adatok megjelenítési képeinek meghatározására szolgálókat), az adatmódosító (manipulációs) műveleteket (frissítés és visszakeresés is), biztonsági és jósági (integritási) korlátokat, valamint a tranzakció kezelési műveleteket (begin, commit és rollback: elkezdés, jóváhagyás és visszagörgetés).

6. A nézetek frissítésének szabálya szerkesztés

A rendszernek képesnek kell lennie az adatok elméletileg frissíthető minden nézetének frissítésére.

7. Magas szintű beszúrás, frissítés és törlés szerkesztés

A rendszernek támogatnia kell az INSERT, UPDATE, és DELETE (új adat, módosítás, törlés) operátorok halmaz szintű, egyidejű működését.

8. Fizikai szintű adatfüggetlenség szerkesztés

A fizikai adatfüggetlenség akkor áll fenn, ha az alkalmazások (programok) és a felhasználók adatelérési módja független az adatok tényleges (fizikai) tárolási és elérési módjától.

9. Logikai szintű adatfüggetlenség szerkesztés

Logikai adatfüggetlenség akkor áll fenn, ha az adatbázis logikai szerkezetének megváltoztatása nem igényli az adatbázist használó alkalmazások (programok) megváltoztatását.

10. Jóság (integritás) függetlenség szerkesztés

Az adatok jóságának (érvényességének) korlátait az adatfeldolgozási programoktól függetlenül kell tudni meghatározni, és azokat katalógusban kell nyilvántartani. Legyen lehetséges a szóban forgó korlátokat – úgy és amikor szükséges – megváltoztatni, anélkül, hogy a meglévő alkalmazásokat szükségtelen módon zavarnánk.

11. Elosztástól való függetlenség szerkesztés

A meglévő alkalmazások működése zavartalan kell, hogy maradjon

  • (a) amikor sor kerül az adatbázis kezelő szoftver elosztott változatának bevezetésére a rendszerben
  • (b) amikor a meglévő elosztott adatokat a rendszer újra szétosztja

12. Megkerülhetetlenség szabálya szerkesztés

Ha a rendszernek van egy alacsony szintű (egyszerre egy rekordot érintő) interfésze, akkor azt az interfészt ne lehessen a rendszer megkerülésére használni, például a relációs biztonsági vagy jósági (integritás védelmi) korlátok megsértésével.

Források szerkesztés

  • E.F. Codd: Is Your DBMS Really Relational?, ComputerWorld, 1985. október 14.
  • E.F. Codd: Does Your DBMS Run by the Rules?, ComputerWorld, 1985. október 21.
  • C.J. Date: An Introduction to Database Systems, (5. kiadás) 389–393 oldal.

További információk szerkesztés