1 / 24

Relační databázová technologie

Relační databázová technologie. Klíč: množina (možná jednoprvková) atributů (sloupců), jež jednoznačně idetifikuje danou entitu. Poznámky: Daný entitní typ (tabulka) může mít více klíčů může být více. Například (i) rodné číslo, (ii) osobní číslo zaměstnance, (iii) syntetický klíč.

brooke
Download Presentation

Relační databázová technologie

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Relační databázová technologie Klíč: množina (možná jednoprvková) atributů (sloupců), jež jednoznačně idetifikuje danou entitu. Poznámky: • Daný entitní typ (tabulka) může mít více klíčů může být více. Například (i) rodné číslo, (ii) osobní číslo zaměstnance, (iii) syntetický klíč. • Každá tabulka má alespoň jeden klíč. V (opravdové) relační databázi nemůže tabulka obsahovat více řádků s týmiž hodnotami v jednortlivých sloupcích.

  2. Relační databázová technologie Cizí klíč: množina (možná jednoprvková) atributů (sloupců), jejichž hodnota určuje hodnotu klíče jiné tabulky. Poznámky: • Datový typ jednotlivých atributů musí být kompatibilní s datovým typem odpovídajících atrinutů klíče referencované tabulky. • Cizí klíč není (nemusí být) v dané tabulce klíčem. • Vztah mezi entitami se realizuje asociativní vazbou cizí klíč -> primární klíč. • Vzhledem k tomu, že tabulka může mít více klíčů, je dobré jeden z nich zvolit a systematicky ho používat k realizaci vztahů s ostatními tabulkami. Takto zvolený klíč nazýváme klíčem primárním.

  3. http://www.sybase.com/products/modelingmetadata/powerdesignerhttp://www.sybase.com/products/modelingmetadata/powerdesigner

  4. Převod konceptuální model -> logický model • Entitní typ -> tabulka • Atribut entitního typu -> sloupec tabulky • Vztah: • 1:1 nebo 1:N: • vztah->cizí klíč na straně N • atribut vztahu -> sloupec tabulky na straně N • N:M: • Vztah -> „vazební“ tabulka • Atribut vztahu -> sloupec vazební tabulky

  5. Konceptuální model Logický model

  6. Slabý entitní typ 1 Notace Crow's Foot

  7. Slabý entitní typ 1 Notace Crow's Foot

  8. Slabý entitní typ 1 Notace Crow's Foot

  9. Slabý entitní typ 1 Notace Crow's Foot Není to divné? Sloupec IČO tu máme 2x Tento sloupec tu bude 2x

  10. Slabý entitní typ 1 Notace Crow's Foot

  11. Slabý entitní typ 2

  12. Slabý entitní typ 2

  13. 11111111 Nemocnice Motol 224 43 11111111 1111 Ústředna 22222222 Honda Motol 234 09 11111111 2920 Kardiocentrum 11111111 2101 Novorozenecké oddělení 22222222 1111 Recepce 22222222 6690 Prodej nových vozů Slabý entitní typ 2 Řídící entitní typ Identifikující vztah (vazba) Slabý entitní typ

  14. Slabý entitní typ 3

  15. Slabý entitní typ 4

  16. Reflexivní vztah 1

  17. Reflexivní vztah 1 Reflexive mandatory reference A reflexive reference exists should not have a mandatory parent which could lead to inconsistent joins.

  18. Reflexivní vztah 2 Nepovinná hodnota cizího klíče

  19. Reflexivní vztah 2 Nepovinná hodnota cizího klíče

  20. Reflexivní vztah 2

  21. Referenční integrita 1 Mějme dvě tabulky A a B takové, že tabulka B obsahuje cizí klíč odkazující to tabulky A. V databázi nesmí dojít k tomu, že pro nějaký řádek tabulky B odkazuje jeho hodnota cizího klíče na neexistující řádek tabulky A.

  22. Referenční integrita 2 • Jak může dojít k porušení referenční integrity? • Zrušíme záznam v tabulce Osoba => cizí klíč příslušného řádku tabulky Zbran bude odkazovat na neexistující řádek tabulky Osoba. • Změníme hodnotu primárního klíče některého řádku v tabulce Osoba=> cizí klíč příslušného řádku tabulky Zbranbude odkazovat na neexistující řádek tabulky Osoba.

  23. Referenční integrita 3

  24. Referenční integrita 4

More Related