OBSAH WEBU
ČTĚTE!
Konceptuální modelování - jedním ze tří kroků návrhu databáze
ERD - entity-relationship, chápe modelovanou aplikační doménu jako množinu entit
Entitní množina - množina entit téhož typu (klient, účet), sdílí stejné atributy
Entita - objekt rozlišitelný od jiných (klient banky s číslem 437)
Atribut - vlastnost entity, která nás zajímá a chceme ji mít v databázi (jméno)
Doména atributu - obor hodnot atributů
Vztah - asociace mezi entitami (klient 437 vlastní účet 100)
Vztahová množina - množina vztahů téhož typu (klient vlastní účet)
Identifikátor (primární klíč) entitní nebo vztahové množiny - atribut jehož hodnota je v dané množině jednoznačná, může být jednoduchý nebo složený atribut
Složené - jméno - křestní | příjmení
Jednoduché (křestní, příjmení) - pokud rozhodneme jméno jako celek (křestní+příjmení) potom je i tento atribut jednoduchý
Jednohodnotové vs. vícehodnotové - například telefon - číslo1, číslo2, …
Povolující prázdnou hodnotu NULL - hodí se například pokud víme, že hodnota existuje, pouze ji v dané chvíli neznáme
Odvozené - věk odvozený z datumu narození
Kardinalita - Maximální počet vztahů dané vztahové množiny, ve kterých může hrát roli jedna entita, vlastnost konce vztahu (nutno „číst“ z obou stran)
Členství - Minimální kardinalita - vyjadřuje minimální počet vztahů dané vztahové množiny (0-volitelné, 1-povinné)
Slabá entitní množina - Je závislá na jiné entitní množině a je pomocí ní identifikovatelná
Silná entitní množina - může existovat sama o sobě
Konceptuální modelování – patří do etapy analýzy požadavků. Cílem je analyzovat požadavky na data, která budou uložena v databázi. Výsledkem je ER diagram základní model v požadavcích na data.
Logický návrh
Fyzický návrh
Přístup
Přístup k návrhu databáze
Normalizace - Zkvalitňování návrhu tabulek - lepší schéma databáze (má lepší vlastnosti)
určitou informaci, složitá kontrola integritních omezení
kvalitu návrhu a postup dekompozice schématu relace, které vykazuje nedostatky.
složitosti dat – atomické hodnoty jednoduchých atributů. 2NF, 3NF a BCNF definují požadované vlastnosti z hlediska funkčních závislostí atributů. Konečně 4NF, 5NF definují požadované vlastnosti z hlediska vícehodnotových závislostí, resp. Závislostí na spojení. 4 a 5 jsme neřešili-
Příklad: Zakladni nijak nenormalizovana databaze:
Pravidlo 1NF říká, že všechny tabulky obsahující opakující se sloupce je třeba rozdělit do nových tabulek, v nichž může být údaj uložen pouze jednou (data o výrobku) a pole tabulky musí obsahovat údaje atomicky dále nedělitelné (adresa)
Pravidlo 2NF říká, že všechny tabulky obsahující sloupce s duplicitními položkami, které mezi sebou vytvářejí částečné závislosti, je třeba rozdělit do tabulek nových, v nichž bude každý údaj uložen pouze jednou. Částečná závislost je pojem, jímž se popisují data, která nelze identifikovat na základě žádného klíče dané tabulky V našem případě to znamená, že když budeme chtít pro jednoho zákazníka vytvořit více objednávek, je třeba pro objednávky vytvořit samostatnou tabulku
Pravidlo 3NF vyžaduje důsledné odstranění a oddělení dat, která nejsou v přímém vztahu s primárním klíčem dané tabulky. Hodnota pole každého záznamu musí být závislá na hodnotě klíčové položky, která jednoznačně identifikuje všechna pole daného záznamu. Pole DodavatelNazev není identifikováno hodnotou pole IDOdberatele. Pole Sleva a Mnozství se také nevztahuje přímo k výrobku ale k řádku objednávky. Proto bylo nutné přidat ještě tabulky Dodavatele a DetailObjednavky. V tabulkách není vhodné uvádět vypočtená pole (ObjednavkaCelkem, Celkem). Tyto hodnoty je lépe vypočítat vždy v okamžiku potřeby pomocí dotazu nebo na formuláři či sestavě.
Číselník - tabulka (v tomto případě Dodavatelé) je tabulka pouze s dvěma sloupci, jednym s daty a druhý je klíč, slouží abychom například u tabulky výrobky nemuseli vypisovat dlouze dodavatele, ale pouze kratce odkazujeme číslem na tabulku dodavatelů.