Co je cílem doménového modelu?
- popsat data, se kterými se bude pracovat
- popis významů termínů - aby jim každý rozumněl
- popis vazeb mezi entitami - pak je to základ pro databázový model (i když ten už se většinou generuje z hotové databáze)
- zachycení atributů jednotlivých entit
Vztah mezi entitami by měl mít vždycky popis:
Diagram tříd
Typy vztahů
Mezi třídami lze vyjádřit čtyři základní druhy vztahů:
- Asociace - běžný vztah mezi třídami (násobnost 0..* na obou stranách)
- Kompozice - silný vztah celku a části, část nemůže existovat bez celku (násobnost 1 na straně vlastníka)
- Agregace - slabší forma kompozice, část může existovat samostatně (násobnost 0..*); doporučuje se ji raději nepoužívat
- Generalizace / Dědičnost - třída B je specializací třídy A
classDiagram class A class B A "0..*" --> "0..*" B : asociace A "1" *-- "0..*" B : kompozice A "0..*" o-- "0..*" B : agregace A <|-- B : generalizace/dědičnost
Násobnosti
Každý vztah může mít na svých koncích uvedenu násobnost, která říká, kolik instancí jedné třídy může být ve vztahu s instancemi druhé třídy (např. 1, 0.., 1..).
Popisy vztahů
Vztahy lze doplnit textovým popisem (jménem asociace nebo rolemi), který upřesňuje jejich význam.
- kompozice = těsný vztah (jedna entita nemůže existovat bez druhé) - používá se spíše u abstraktnějších věcí než u fyzických
- s kompozicí opatrně, je hodně striktní
- agregace = něco mezi asociací a kompozicí (radí se moc nepoužívat)
- co se týče dědičnosti, tak je to dost striktní vazba, takže s ní opatrně
- mrkni, jestli se spíše nedá vyjádřit asociací
- například: mám Vedoucího tábora a Hlavního vedoucího tábora (místo toho, abych dědil, tak přidám vazbu na Tábor “je vedoucím” a druhou vazbu “je hlavním vedoucím” - tím pádem nedojde k duplikaci)
- při udělování dědičnosti řeš možné duplikace a kdy mohou nastat (s tím jsem měl problém v testu)
- mrkni, jestli se spíše nedá vyjádřit asociací
Diagram tříd - asociační třída
Asociační třída se ve většině případů nepoužívá - obvykle si vystačíme bez ní.
classDiagram A "0..*" -- "0..*" B A -- C B -- C
Třída C je asociační třída navázaná na vztah mezi třídami A a B (znázorněno přerušovanou čarou vedoucí ze středu asociace dolů k C).
- váže se k asociaci a přidává další atributy (např. délka trvání vztahu)
Třídy (entity) jsou předměty, objekty z reálného světa, či podstatná jména z business modelů, UC modelu či slovníčku pojmů (= glosáře, viz TUR)
Násobnosti
0..1 0..* 1..1 nebo jenom 1 1..*
Modelování stavů entit
- pro názornost (a přehlednost) lze pro nějaké entity ještě namodelovat stavy
Stavový diagram
Stavový diagram zachycuje stavy objektu a přechody mezi nimi. Klíčové pojmy:
- Stav - situace, ve které se objekt nachází
- Přechody - změny mezi stavy, popsané ve formátu Událost[Podmínka]/Akce
- Pozor - nejde o diagram aktivit!
Příklad: stavový diagram výtisku knihy
stateDiagram-v2 [*] --> Volny : Nákup výtisku Volny --> Vyrazeny : Pravidelná kontrola [výtisk je poškozený] Volny --> Vypujceny : Žádost o výpůjčku [výtisk není rezervovaný] / Zaznamenání výpůjčky výtisku dané knihy Vypujceny --> Volny : Vrácení výtisku Vypujceny --> Ztraceny : Nahlášení ztráty [uhrazena pokuta]
- u výstupních hran se uvádí událost kvůli které se entita převedla do jiného stavu