Adatbázis- és szoftverfejlesztés

Slides:



Advertisements
Hasonló előadás
Adatbázis-kezelés Készítette: Asztalos Péter január 12.
Advertisements

Az adatbázis kezelés alapjai
ADATBÁZISOK.
Adatbázis gyakorlat 1. Szerző: Varga Zsuzsanna ELTE-IK (2004) Budapest
A normalizálás az adatbázis-tervezés egyik módszere
Adatbázis rendszerek I.
Access Adatbáziskezelés
Adatbázisok SQL. TARTALOM Szijártó M.2 Témakörök  Az SQL tulajdonságai  A műveletek fajtái  Objektum-műveletek  Lekérdezések Tulajdonságok és műveletek.
Adatbázis-kezelés.
Relációs adatbázisok készítése
Függőségek, normálformák
SQL Structured Query Language
Adatbázis kezelés. Hierarchikus modell Legrégebbi modell, ma már nem használatos. Az adatokat fákban tároljuk, ahol minden pont a szegmens adatokat, és.
Adatbázis (alapfogalmak).
EE/R adatmodell (Extended E/R) 1 Az objektum orientált szemlélet elterjedésével egyre nőtt az igény az olyan SDM (Semantic Data Model) modellek iránt,
Microsoft Access I. Készítette: Rummel Szabolcs
Microsoft Access V. Készítette: Rummel Szabolcs Elérhetőség:
Információ kezelés Az információ visszakeresésének lehetőségei.
Adatbázis-kezelés.
Az adatbázissal kapcsolatos tudnivalók
KOVÁCS DÁVID. ALAPFOGALMAK Adatbázis: Olyan adatgyűjtemény, amely egy adott feladathoz kapcsolódó adatokat szervezett módon tárolja, és biztosítja az.
16. Tétel. Adatbázis: Olyan adatgyűjtemény, amely egy adott feladathoz kapcsolódó adatokat szervezett módon tárolja, és biztosítja az adatokhoz való hozzáférést,
2011. szeptember Az információtechnológia menedzselése Az információs rendszer fejlesztése Image of the slide: www2.raritanval.edu/departments/busadmin/.../Ch07-IntrotoBusiness.ppt.
az MSAccess programmal
Adatmodellek - egy eszközrendszer, mellyel leírható a vizsgált valóság, - több különböző absztrakciós szinten is létezhet, - megkülönböztetünk DBMS-hez.
Az adatfeldolgozás forrásai
Adatbázis-kezelés Papp-Varga Zsuzsanna. Elérhetőségek    as.
SQL, Relációs adatmodell
Anyagadatbank c. tárgy gyakorlat Féléves tematika Adatbázis alapfogalmak, rendszerek Adatmodellek, adatbázis tervezés Adatbázis műveletek.
Tervezés, Normalizálás
Térkép. Mi az adat? Minden információ, amit tárolni kell. Minden információ, amit tárolni kell.  szám  szöveg  dátum  hang  kép, stb.
Statisztika, kutatásmódszertan I.
Adatbázisrendszerek világa
Adatbázisok Adatbázis: adatok gyűjteménye, amelyeket az adatbázis-kezelő rendszer (DBMS –Database Management System) kezel. Kezelt adatrendszer → adatbázis.
Dr. Krauszné Dr. Princz Mária Adatbázis rendszerek I.
1 Informatikai Szakképzési Portál Adatbázis kezelés Alapfogalmak.
Adatbázis-kezelés JAG,
11. tétel Adatbázis táblái közti kapcsolatok optimalizálása
Adatbázisok gyakorlat
Adatbázis kezelés. Az adatbázis tágabb értelemben egy olyan adathalmaz, amelynek elemei – egy meghatározott tulajdonságuk alapján – összetartozónak tekinthetők.
SQL nyelv részei DDL (Data Definition Language – Adat Definiáló Nyelv)  relációs séma séma kezelő utasítások: adatbázisok, táblák létrehozása, módosítása.
Adatbázis kezelés.
Adatbázis-kezelés.
Adatbázis rendszerek I Relációs adatmodell strukturális része Általános Informatikai Tsz. Dr. Kovács László.
Adatbázis-kezelés Probléma: az excel kezelhetetlen túl sok adat esetén
Adatbázisok Fleiner Rita, Tankönyv:
Adatbázis-kezelés Készítette: Asztalos Péter január 12.
Adatbázis-kezelés.
Adatbázis alapfogalmak
(A logikai adatmodell kialakítása)
Webprogramozó tanfolyam
Normálformák Takács Gábor mérnök informatikus, okl. mérnöktanár
Adatbázis-kezelés. Alapfogalmak Adat: –észlelhető, felfogható ismeret –jelsorozat –valakinek, vagy valaminek a jellemz ő je –tény, közlés Információ:
Gáspár Bencéné Dr. Vér Katalin
Információs rendszer fejlesztése 2. előadás
Adatbáziskezelés. Adat és információ Információ –Új ismeret Adat –Az információ formai oldala –Jelsorozat.
Adatbázis-kezelés 1-2. adatbázis-kezelő rendszer 1.új adatbázisokat hozhassanak (adat definició 2.lekérdezések és módosítások (adat manipuláció) 3.Támogassa.
Adatbázisszintű adatmodellek
ACCESS ALAPOK Alapfogalmak
Programozás III JPA.
Gazdasági informatika II (SZIE GTK GVAM 1. évfolyam) 2009/2010. tanév 2. félév.
Az adatbázis az adatok és a köztük lévő összefüggések rendszere, amelyet egymás mellett tárolunk. Nagyon fontos, hogy az adatbázisunk szerkezetét jól megtervezzük,
Szemantikai adatmodellek
Alapfogalmak Adat: rögzített ismeret
Adatbázis alapismeretek
Kovács Gergely Péter Bevezetés
Logisztikai projekt - gyakorlat Adatbázis-elmélet
Relációs adatmodell, normálformák
Adatbázis-kezelés 2. Relációs adatbázisok.
Adatbázis-kezelés.
Előadás másolata:

Adatbázis- és szoftverfejlesztés 4. évfolyam

ADATBÁZISOK A KÖRNYEZETÜNKBEN Hol találkozunk adatokkal a mindennapi életben? Példa: TAJ, bankkártya, film, könyv…stb. adatok. Az ADAT fogalma: A számítástechnikában adatnak definiáljuk a számokkal leírható, a számítástechnika eszközeivel rögzíthető, feldolgozható és megjeleníthető objektumokat. Az információ olyan adat vagy ismeret, amely viselkedésünket befolyásolni képes. Az adathalmaz: Adatok sokasága. Az adathalmaz akkor alakul át adatbázissá, ha az valamilyen meghatározott szempontok szerint felépített, és lehetővé teszi az adatok szisztematikus kezelését, elérhetőségét. Tehát az adatból, a feldolgozás során válik információ.

Az adat tehát akkor tekinthető definiáltnak, ha meghatározzuk, hogy milyen objektum melyik változója, milyen értéket vesz fel. Milyen értékeket vehet fel a példában szereplő objektumok tulajdonságai?

ADATBÁZIS ALAPVETŐ FOGALMAI: Adatbázistervezéshez fontos ezekkel tisztában lenni. Adatbázis: adatok gyűjteménye, rendezett sokasága és egy adatbázis-kezelő rendszer kezel (DBMS). Többfelhasználós, kapcsolatok – összefüggések rendszere. Kulcs: egyértelmű azonosítója egy egyednek. Megkülönbözteti a többi egyedtől. Tábla: Adatokat táblában tároljuk. Sorai és oszlopai vannak (mezők, rekordok). Mező: tábla egy oszlopa egy jellemző tulajdonsággal Rekord: a tábla egy sora, konkrét adattal.

ADATBÁZIS-SZERKEZETEK, ADATMODELLEK: Egy adatbázis-kezelő rendszer mindig egy adatmodellre épül, amely tulajdonképpen a valós folyamatok absztrakt leképezése, egyedek, tulajdonságok és kapcsolatok halmaza. Egy eszközrendszer, amellyel leírható az adatok és a kapcsolataik, a tervezés és az elemzés szempontjából lényeges típusjegyekkel, illetve a közöttük lévő kapcsolatokkal (egyedtípus, tulajdonságtípus, kapcsolattípus). Alacsony szintű adatmodell: hálós, hierarchikus, relációs. Magas szintű adatmodell: E/R modell: Entity-Relationship, azaz Egyed-Kapcsolat modell.

ADATMODELL: Külső (logikai) vagy nézet szint: leírja az adatbázis megjelenését úgy, ahogy azt a felhasználók láthatják, és ahogyan az adatok különbözően megjelennek az adathozzáférési jogoktól függően. Az egyes felhasználókat más-más adat, és annak (logikai) összefüggései érdeklik. Talán természetes is, hogy határozottan eltérő irányokból szemlélnek, értékelnek egy ugyanazon jelenséget és a különböző ismereteik szerint dolgozzák fel azt. Koncepcionális (fogalmi) szint: ez a szint írja le a mindenki számára elérhető adatok megjelenését, formáját, az adatbázis összes objektumának szerkezetét és a közöttük lévő kapcsolatokat, valamint az objektumokhoz történő hozzáféréseket. Kettős funkciót lát el: 1. Adatbázissá szervezi az egyéni, külső szemléleteket. 2. Összekapcsolja a logikai és fizikai szintet. Ez alkotja a logikai vázat, a modellt. Belső (fizikai) szint: a fizikai tárolás és elérés módjának leírása. Az adatok tényleges elhelyezkedése, tárolása, kapcsolódásai nem tartoznak a felhasználóra, ezért a felhasználó nem kezel indexeket, mutatókat, láncokat, hozzáférést. Amennyiben a körülmények azt teszik szükségessé, úgy az adatokat többszörösen is tárolni kell. Esetenként különböző gépeken és eltérő adatkezelőkkel feldolgozottan is. A fizikai kezelésmódot a rendszer biztosítja.

ADATMODELLEK ELEMEI: Egyed (entitás): a valós világnak az az eleme (tárgy, jelenség, elképzelés, személy, fogalom stb.), amely a modellezés tárgyát képezi. Tulajdonság (attribútum): az egyednek a modellezés szempontjából lényeges jellemzőinek halmaza.

ADATMODELLEK: Hierarchikus adatmodell: Az adatokat egy fastruktúra-szerű hierarchikus szerkezetben tárolja, amely egy fához hasonlítható leginkább. A fa mindegyik csomópontja egy rekordtípusnak felel meg. Előnye, hogy a hierarchikus szerkezet egyszerűen leírható, könnyen elkészíthető, mágnesszalagon is tárolható. Jobbára nagygépes környezetben fordult elő. Ma már ez az adatbázis-szerkezet elavult, így napjainkban csak történeti jelentősége van.

ADATMODELLEK: Hálós adatmodell: A hierarchikus modell továbbfejlesztése. Ebben a modellben az adatok között tetszőleges kapcsolatrendszer alakítható ki. Egy adatnak több őse is lehet, egy „szülő” és több „gyermek” rekord pl. lehet egy vállalati osztály és a dolgozói. Hátránya: bonyolult kapcsolatok, nagy tárolóigény. Ez is nagygépes környezetben fordult elő, ma már szintén csak történeti jelentőséggel bír. Pl. Vállalat – Osztály – Dolgozó

ADATMODELLEK: Relációs adatmodell: A különböző jellegű, de mégis kapcsolatba hozható adathalmazokat önálló állományokban (táblákban) tároljuk, amely állományok (táblák) között egy azonos adatot tartalmazó mező tartja a kapcsolatot. A relációs modellre épülő adatbázis-kezelőket RDBMS-nek (Relational DBMS) nevezzük. Szabványos leíró/lekérdező nyelvük az SQL. Ez a legelterjedtebb modell. Reláció: A relációt táblázatban szokás ábrázolni. A reláció egy eleme a táblázat egy sora. a reláció olyan táblázatnak tekinthető, melynek nem lehetnek azonos sorai (rekordjai), a sorok sorrendje tetszőleges, a sorok és oszlopok találkozásában mindig csak egy érték van, az oszlopok a reláció attribútumai. Funkcionális függőség: A P attribútum halmaz funkcionálisan meghatározza a Q attribútum halmazt, P→Q, ha P értékei és Q értékei között, P irányából egyértelmű hozzárendelés van, azaz egy reláción belül igaz, hogy ha P értékei megegyeznek a reláció két sorában, akkor Q értékei is megegyeznek ebben a két sorban. (P minden értékéhez Q-nak pontosan egy értéke tartozik.) Funkcionális függőségek egy relációban: A kulcs funkcionálisan meghatározza a reláció többi attribútumát. Egy relációban nemcsak a kulcs határozhat meg funkcionálisan egy attribútumot, ezek a nem kulcsjellegű funkcionális függőségek. A nem kulcsjellegű funkcionális függőségek egy relációban redundanciát okoznak, állomány-karbantartáskor pedig következetlenséget, anomáliát okozhatnak.

IDEGEN (KÜLSŐ) KULCSOK: A normalizált adatállomány részei között 1:N kapcsolat alakul ki, amelyet a funkcionális függőség határoz meg, ezért a modell-egyed kapcsolati diagramon is ábrázolható. A kapcsolatokat azok az attribútumok biztosítják, amelyek a kapcsolódó adatállományok mindegyikében megtalálhatók, és az egyikben kulcsként szerepelnek, a másikban nem (másodlagos attribútumok, vagy a kulcs valódi részei). Ezek az attribútumok az idegen kulcsok. Objektumorientált modell: Az objektumorientált programozási nyelvek a C++ nyelvhez hasonló szabvány, eszközrendszer az adatstruktúrák leírására. Leíró nyelve az ODL (objektum definíciós nyelv), lekérdező nyelve az OQL (objektum lekérdező nyelv). Az objektumorientált modellre épülő adatbázis-kezelő rendszereket OODBMS-nek nevezzük (Object Oriented DBMS).

ELSŐDLEGES KULCS (primary key): INDEXEK: Az egyes táblák rendezését, ill. keresését meggyorsító funkció. ELSŐDLEGES KULCS (primary key): Egyértelműen azonosítja a tábla sorait. Sok esetben generált érték (serial). ÖSSZETETT ELSŐDLEGES KULCS (primary key): Több mezőből álló elsődleges kulcs EGYEDI KULCS (unique): Egyedi érték, két ugyanolyan nem létezhet belőle.

Írjunk példákat táblákra és rendeljünk hozzá kulcso(ka)t! Pizza rendelés nyilvántartásban. Dolgozó nyilvántartásban.

EGYED-KAPCSOLAT MODELL: Egy adatbázis létrehozása során első lépésként rendszerint az E/R modell segítségével létrehozzuk a problémakör adatstruktúrájának megfelelő leírást. Több úton haladva is létrehozhatjuk az E/R leírást, de célszerű az általánosan bevált módszert alkalmazni. Előbb a fontosabb, lényegesebb elemeket határozzuk meg, majd ezekre alapozva később finomítjuk, kibővítjük a modellt az egyéb, kevésbé fontos elemekkel. Az E/R modell esetén a központi szerepet az egyedek játsszák, mivel köréjük csoportosulva léteznek a tulajdonságok és a kapcsolatok is. Az egyedek nélkül sem tulajdonság, sem kapcsolat nem létezik, ezért a tervezés során célszerű elsőként a problématerületen megjelenő egyedeket számba venni, nevet és jelentést adva nekik.

EGYED-KAPCSOLAT MODELL: Az egyedek felrajzolása után sorra vehetjük az egyedek között fennálló kapcsolatokat, kijelölve a kapcsolatok jellegét is. Az egyedek és a kapcsolatok együtt alkotják az E/R modell gerincét, vázát. Alapvetően ez a váz határozza meg a későbbiekben létrehozandó DBMS adatmodell struktúráját is. Az egyedek és kapcsolatok megadása után sorba vehetjük, hogy milyen információkra van szükség az egyes egyedekre és kapcsolatokra vonatkozóan. A tulajdonságok kijelölésénél ügyeljünk arra, hogy milyen értékeket vehetnek fel, megkülönböztetve a többértékű és összetett és származtatott tulajdonságokat.

EGYED-KAPCSOLAT tervezés lépései: egyedek meghatározása, kapcsolatok meghatározása, tulajdonságok meghatározása. Egy magas szintű adatmodellből lehetséges egy alacsony szintű adatmodellre való áttérés, amelyet az ún. leképezési szabályok tesznek automatikussá. Így, a magas szintű adatmodellt (pl. E/R modell) a leképezési szabályokkal, egy másik, adatbázis-kezelő függő, alacsonyabb szintű (pl. relációs) modellre alakíthatunk át. Ez a leképezés az ún. CASE eszközök segítségével automatizálható.

CASE eszközök: olyan programcsomag, amelynek moduljai egy rendszer fejlesztésének teljes folyamatát támogatják, a problémadefiniálástól a kivitelezésen át a bevezetésig, az üzembe helyezésig és elkészítik a rendszer-dokumentációt. Az adatbázis megtervezéséhez nagyszámú feltételt és körülményt kell figyelembe venni. Az elemzés eredményét egy olyan adatmodellben kell tárolni, amely közvetlenül felhasználható az adatbázis létrehozásához. A nagy adatmennyiség mellett, egy ebből fakadó másik problémát jelent, hogy a tervezés rendszerint nem egy ember munkája, hanem csapatmunka. Emiatt különös gondot kell fordítani a dokumentációk szabványosságára, a feladatok kiosztására. A CASE eszközök jelentős segítséget nyújtanak a tervezésben, a csoportmunka összehangolásában. A CASE komponens eredménye legtöbb esetben közvetlenül felhasználható az űrlapok, jelentések és menük generálásához. Egyszerű modellező, tervező szoftver pl.: DBDesigner-Fork

Entity-Relationship (E/R), azaz Egyed-Kapcsolat (E/K) diagram Az egyedekkel, tulajdonságokkal és kapcsolatokkal, valós világ jelenségeit leíró modellt egyed-kapcsolat modellnek, az ezt ábrázoló diagramot egyed-kapcsolat diagramnak nevezik. Rövidítve így is ismerhetjük: E/K modell és E/K diagram. Az angol elnevezése alapján - entity-relationship modell - az E/R modell és E/R diagram elnevezések is elterjedtek. A 8. ábra egy könyvtári rendszer E/R diagramja. Az egyed-kapcsolat diagramoknak szabványos jelölésrendszerük van: téglalappal az egyedeket, ellipszissel az attribútumokat, rombusszal a kapcsolatokat, dupla téglalappal a gyenge egyedhalmazokat, dupla rombusszal a sok-egy kapcsolatot, aláhúzással az elsődleges (szuper)kulcshoz tartozó tulajdonságokat jelölik.

E/R egyed – kapcsolat diagram:

Adatdefiníciós nyelv – DDL: CREATE TABLE tablename... CREATE TABLE employees ( id INTEGER PRIMARY KEY, first_name VARCHAR(50) not null, last_name VARCHAR(75) not null, fname VARCHAR(50) not null, dateofbirth DATE not null ); Adatmanipulációs nyelv – DML: UPDATE tablename SET … INSERT INTO employees(first_name, last_name, fname) VALUES ('John', 'Capita', 'xcapit00'); Lekérdező nyelv – QL: SQL SELECT: SELECT * FROM employees;

ADATBÁZIS TERVEZÉS LÉPÉSEI: Egy adatbázis tervezése során először az adatbázisunkat meghatározó rendszer felépítését, működését kell megismernünk, és elemzésekkel meghatároznunk a feldolgozandó adatok körét, valamint az adatbázissal szemben támasztott igényeket.

Kapcsolat foka az egyedek között fennálló viszonyt hordozza. Ezt követően megvizsgáljuk a logikailag összetartozó adatok közötti kapcsolatokat. Így hozzuk létre a tervezett rendszer specifikációját vagy logikai modelljét. Ezután a felhasználható szoftver- és hardverkörülmények figyelembevételével fizikai szinten is létrehozzuk az adatbázisunkat. Kapcsolat foka az egyedek között fennálló viszonyt hordozza. A kapcsolat fokát a két egyed előfordulásai közötti összefüggés számossága határozza meg, ami alapvetően háromféle lehet: Egy az egyhez kapcsolatban az összefüggések az egyedek előfordulásai között mindkét irányból egyértelműek (1:1). Egy a többhöz kapcsolatban az összefüggések csak az egyik irányból egyértelműek (1:N). Több a többhöz kapcsolatban az összefüggések egyik irányból sem egyértelműek (N:M).

ADATBIZTONSÁG, ADATINTEGRITÁS, ADATREDUNDANCIA Konkurens adatkezelés: több felhasználó egyidejű hozzáférése az adatokhoz! Rugalmasság: Egyszerű adatszerkezet módosítása. Adatfüggetlenség: Az adatszerkezet függetlensége programoktól, tárolóeszköztől. Hatékonyság: A számítógép adottságainak jó kihasználása. Adatbiztonság: Az adatok védelme. Adathozzáférési szintek: jogosultság, amely biztosítja, hogy a konkurens hozzáférés esetén is módosíthassák. Adatredundancia: Egy adatot csak egy helyen tárolunk. (Miért?) Adatintegritás: adathelyesség, adatteljesség, adatösszefüggések megőrzése...

ADATBIZTONSÁG, ADATINTEGRITÁS, ADATREDUNDANCIA Annak a feltételnek a megléte, hogy az adat helyes, és semmiféle művelet, mint például adatátvitel, tárolás, visszaállítás nem károsította meg az eredeti adatot. Az adat helyesen áll rendelkezésre a kezelés számára. Integritás: Rosszindulat miatti módosulás: Támadó szándék Helytelen kezelés Üzemzavar miatti módosulás: Adatátviteli hibák Adathordozó hibák Relációs adatbázis-kezelő rendszerek adatintegritása: Naprakészség Megbízhatóság Érvényesség

ADATBIZTONSÁG, ADATINTEGRITÁS, ADATREDUNDANCIA Nézzük meg a videót és beszéljük meg mi történt! SQL Injection!

ADATBÁZISKEZELŐ RENDSZEREK Gyakorlatban előforduló RDBMS: Cél: adatok gyors tárolása, elérhetősége. Gyakorlatban előforduló RDBMS: MySQL PostgreSQL Firebird SQL (Interbase SQL) Oracle SQL MS-SQL SAP DB Informix Ingres Sybase IBM DB/2 …stb.

Nézzünk egy példát a DBDesigner-Fork nyílt forráskódú alkalmazással. Tervezzünk meg egy pizza rendelés adatbázisát! Egyedek: pizza(kód, név, ár), rendelések(azon,dátum), futár(fkód,neve). Generáljuk le a MySQL, PostgreSQL adatbázis SQL állományt! Hasonlítsuk össze a két SQL állományt!

NORMÁLFORMÁK: Név Cím Telefon A redundancia kiküszöbölésére vezették be a normálformákat (NF). Meghatározásukhoz az attribútumok csoportosítására van szükség. Elsődleges attribútumoknak nevezzük egy relációban azokat az attribútumokat, amelyek a reláció valamelyik kulcsának részei, a többi attribútumot a relációban másodlagos attribútumnak nevezzük. Név Cím Telefon Első Péter Budapest 1/1234567 1/1234568 Második István Gyöngyös 23/123456

Első normál forma (1NF): 1NF-ban van az adatállomány, ha minden tulajdonsága elemi, azaz minden előfordulásra csak egy értéket vesz fel. Az 1NF-ban lévő adatállomány minden tulajdonsága (attribútuma) funkcionálisan függ a kulcstól. Minden sorban egy atributum érték van. Második normálforma (2NF): 2NF-ban van az adatállomány, ha 1NF-ban van, és nem tartalmaz részleges függést, azaz nincs olyan másodlagos attribútuma, amely funkcionálisan függne a kulcs valódi részétől. Részleges függésről, csak összetett kulcs esetén beszélhetünk, ezért az 1NF-ben lévő és egyszerű kulccsal rendelkező adatállomány egyúttal 2NF-ben is van. Példa: a BIZONYLATFEJ és BIZONYLATTÉTEL esete Általában mindenféle bizonylat, ami több tételt is tartalmazhat, mindig fej- és tétel-adatokra fog bomlani, ugyanis vannak olyan tulajdonságok, amik csak a bizonylat számától függnek teljesen, és vannak azok, amelyek egyértelmű meghatározásához a bizonylatszám mellett legalább a tételsorszámra szükség van. (Rendelés-mintánkban a tételt a rendszám és cikkszám azonosította.) NÉV SZAKKÉPZETTSÉG SZÜLETÉSI DÁTUM Nagy Zsolt gépészmérnök 52.02.16 közgazdász Kiss Pál lakatos 58.08.08 BIZAZON DATUM VEVO VEVOCIM 101 2016.08.09 Első Kft. Bp. Petőfi u. 3. 102 2016.08.10 Második Kft. Bp. Andrássy út 4. TETELSZAM BIZAZON TERMEK AR AFA 1 101 TERM1 1000 27 2 TERM2 2000

Harmadik normálforma (3NF): 3NF-ban van az adatállomány, ha 2NF-ban van, és nem tartalmaz tranzitív függést, azaz nincs olyan másodlagos attribútuma, amely funkcionálisan függne egy másik másodlagos attribútumtól. Példa: a BIZONYLATFEJ és PARTNER esete Általában mindenféle bizonylat pontosan egy partnertől érkezik, és az a partner több bizonylatot is küldhet. A partner sok törzsadata mellett bizonyára kap egy kódot nálunk, aminek valóban be kell kerülni a bizonylatfejbe, de a többi törzsadatnak nem. A partner kódja a partner táblában lesz kulcs, ami mellett a többi törzsadatot tároljuk helyesen. Normálformák kialakítása, normalizálás: Az optimális szerkezet kialakítása a normalizálatlan állomány szétbontásával történik, a nem kulcsjellegű funkcionális függőségek kiküszöbölésével. A műveletet dekomponálásnak nevezzük, ez olyan részekre bontást jelent, hogy a részekből az eredeti visszaállítható. A részek összekapcsolása az idegen (külső) kulcs segítségével történik CÉL: 3NF kialakítása! VEVOAZON VEVONEV CIM 11001 Első Kft. Bp. 11002 Második Kft. BIZAZON DATUM VEVOAZON 101 2016.08.09 11001 102 2016.08.10 11002 TETELSZAM BIZAZON TERMEK AR AFA 1 101 TERM1 1000 27 2 TERM2 2000 3 TERM3 3000 4 102 TERM4 4000 5 TERM5 5000

Köszönöm a figyelmet!