Kapitel 3: Datenbanksysteme

Ähnliche Dokumente
Kapitel 7: Normalformen

Kapitel 7: Normalformen

3. Normalform. Redundanz: Land mehrfach gespeichert Anomalien?

Kapitel 7: Normalformen

Kapitel 3: Datenbanksysteme

Kapitel 3: Datenbanksysteme

Relationale Entwurfstheorie (Teil 2)

5. Relationale Entwurfstheorie

Kapitel 3: Datenbanksysteme

Dieser Foliensatz darf frei verwendet werden unter der Bedingung, dass diese Titelfolie nicht entfernt wird.

Normalformen. Was sind Kriterien eines guten Entwurfs? So wenig Redundanz wie möglich. Keine Einfüge-, Lösch-, Änderungsanomalien

Vorlesung Datenbankmanagementsysteme

Rückblick: Relationales Modell

Zerlegung einer Relation

d.h. zu Definitions-Stelle eindeutiger Funktionswert x X! y Y : (x,y) f umgekehrt: (x 1,y), (x 2,y) f ist o.k. X Y f(x) = y

Eigenschaften von Datenbanken, insbesondere

Kapitel 3: Datenbanksysteme

Kapitel 6: Das E/R-Modell

Kapitel 2: Das Relationale Modell

Entwurfstheorie relationaler Datenbanken 7. Entwurfstheorie relationaler Datenbanken

Kapitel 11. Normalisierung

Inhaltsverzeichnis. Vorwort Kapitel 1 Einleitung... 15

Kapitel 3: Datenbanksysteme

Datenbanken und SQL. Kapitel 3. Datenbankdesign Teil 1: Normalformen. Edwin Schicker: Datenbanken und SQL

Inhaltsverzeichnis. Vorwort 13. Kapitel 1 Einleitung 15

Datenbanken 6: Normalisierung

TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.

4. Normalisierung von Relationenschemata

Datenbanken 6: Normalisierung

Kapitel 2: Das Relationale Modell

Finalklausur zur Vorlesung Datenbanksysteme I Wintersemester 2003/2004 Prüfer: Prof. R. Bayer, Ph.D. Datum: Zeit: 16.

Matthias Schubert. Datenbanken. Theorie, Entwurf und Programmierung relationaler Datenbanken. 2., überarbeitete Auflage. Teubner

Wiederholung VU Datenmodellierung

Übung Datenbanksysteme Updates, Integritätsbedingungen, funktionale Abhängigkeiten

Welche Kunden haben die gleiche Ware bestellt? select distinct a1.name, a2.name from Auftrag a1, Auftrag a2 where a1.ware = a2.ware.

Auf einen Blick. Abfrage und Bearbeitung. Erstellen einer Datenbank. Komplexe Abfragen. Vorwort... 13

Verfeinerung des relationalen Schemas

funktionale Abhängigkeiten: Semantik funktionale Abhängigkeiten: Syntax

Auf einen Blick. Abfrage und Bearbeitung. Erstellen einer Datenbank. Komplexe Abfragen. Vorwort 13

Wiederholung VU Datenmodellierung

Rückblick: Relationale Entwurfstheorie

Die Bestellungen eines Schreibwarengeschäftes sollen auf eine aktuelle Form mit Hilfe einer zeitgemäßen Datenbank umgestellt werden.

3. Das Relationale Datenmodell

Relationale Datenbanken

Datenbanken. Rückblick: Datenbank-Entwurfsprozess. Semantische Datenmodellierung (vgl. Kapitel 2)

Die Anweisung create table

Rückblick: Datenbankentwurf

S.Müllenbach Datenbanken Informationsanalyse Normalformen- 1. Kurse. Name TNR ...

Datenbanksysteme 2013

3. Grundlagen relationaler Datenbanksysteme

Übungsblatt 10: Lösungsvorschlag

TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.

Das SQL-Schlüsselwort ALL entspricht dem Allquantor der Prädikatenlogik

Wirtschaftsinformatik 7a: Datenbanken. Hochschule für Wirtschaft und Recht SS 16 Dozent: R. Witte

konzeptionelles DB-Design

Kapitel 6: Das E/R-Modell

Logischer Entwurf. Stufen der Entwicklung einer Datenbank. Inhalt. Übersicht. 1. Datenbank - Entwurf ( ER - Diagramm)

Informationssysteme. Prof. Dr.-Ing. Sebastian Michel TU Kaiserslautern. Sommersemester

Kapitel 8: Datenintegrität

Daniel Warner SQL. Das Praxisbuch. Mit 119 Abbildungen. Franzis

Übung 9. Tutorübung zu Grundlagen: Datenbanken (Gruppen Do-T24 / Do-T31 WS 2016/2017)

TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.

9. Normalformen / Erweiterungen 9.1 Vorbemerkung, Zielsetzung, Inhalt Datenmodellierung und Integritätsaspekte

9. Logischer DB-Entwurf

Informatik 10 Mar Datenbanken: RDM Normalisierung April 2014

Datenbanken Unit 7: Normalisierung ctd.

Erstellen von relationalen Datenbanken mit Hilfe der Nomalisierung

Oberfläche SQL. Menü SQL. Formular. Kapitel 1: Datenbank- Administrator (DBA) Anwendungs- Programmierer. Datenbank- Verwaltungssystem (DBMS)

Datenhaltung. Sommersemester Relationale Algebra Join Entity Relationship Model Kardinalitäten... 2

Grundlagen von SQL. Informatik 2, FS18. Dr. Hermann Lehner (Material von Dr. Markus Dahinden) Departement Informatik, ETH Zürich

5/14/18. Grundlagen von SQL. Grundlagen von SQL. Google, Facebook und Co. setzen auf SQL. Whatsapp

Tag 4 Inhaltsverzeichnis

Transkript:

LUDWIG- MAXIMILIANS- UNIVERSITY MUNICH DEPARTMENT INSTITUTE FOR INFORMATICS Skript zur Vorlesung: Einführung in die Informatik: Systeme und Anwendungen Sommersemester 2008 Kapitel 3: Datenbanksysteme Vorlesung: Prof. Dr. Christian Böhm Übungen: Annahita Oswald, Bianca Wackersreuther Skript 2004 Christian Böhm, Peer Kröger http://www.dbs.ifi.lmu.de/lehre/infonf

Überblick 3.1 Einleitung 3.2 Das Relationale Modell 3.3 Die Relationale Algebra 3.4 Mehr zu SQL 3.5 Das E/R-Modell 3.6 Normalformen 2

Relationaler Datenbank-Entwurf Schrittweises Vorgehen: Informelle Beschreibung: Pflichtenheft Konzeptioneller Entwurf: E/R-Diagramm Relationaler DB-Entwurf: Relationenschema In diesem Kapitel: Normalisierungstheorie als formale Grundlage für den relationalen DB-Entwurf Zentrale Fragestellungen: Wie können Objekte und deren Beziehungen ins relationale Modell überführt werden Bewertungsgrundlagen zur Unterscheidung zwischen guten und schlechten relationalen DB-Schemata 3

Motivation Normalisierung Nicht immer liefert das E/R-Modell ein redundanzfreies Datenbankschema: Kunde bestellt Produkt Name AuftrNr Datum Bez Schema: Kunde ( Name,... ) Produkt ( Bez,... ) bestellt ( Name, Bez, AuftrNr, Datum ) Redundanz: Kundenauftrag für mehrere Produkte 4

Motivation Normalisierung Tabelleninhalt Bestellt: Name Bez AuftrNr Datum Huber Schraube 01 01.01.02 Huber Nagel 01 01.01.02 Huber Schraube 02 01.02.02 Meier Schraube 03 05.01.02 Hier gibt es offensichtlich einige Redundanzen: zwei verschiedene Datums zu einem Auftrag möglich zwei verschiedene Kunden zu einem Auftrag möglich Redundanzen durch funktionale Abhängigkeiten Datum funktional abhängig von AuftrNr Name funktional abhängig von AuftrNr 5

Weiteres Beispiel Datenbankschema aus Kapitel 3.3: Kunde Auftrag Lieferant (KName, KAdr, Kto) (KName, Ware, Menge) (LName, LAdr, Ware, Preis) Das Schema Lieferant hat folgende Nachteile: Redundanz für jede Ware wird die Adresse des Lieferanten gespeichert, d.h. die Adresse ist mehrfach vorhanden Insert-/Delete-/Update-Anomalien update: Adressänderung in 1 Tupel insert: Einfügen eines Lieferanten erfordert Ware delete: Löschen der letzten Ware löscht die Adresse 6

Verbesserung Datenbankschema aus Kapitel 3.3: Kunde Auftrag LiefAdr Angebot Vorteile: keine Redundanz keine Anomalien Nachteil: (KName, KAdr, Kto) (KName, Ware, Menge) (LName, LAdr) (LName, Ware, Preis) Um zu einer Ware die Adressen der Lieferanten zu finden, ist Join nötig (teuer auszuwerten und umständlich zu formulieren) 7

Ursprüngliche Relation Die ursprüngliche Relation Lieferant kann mit Hilfe einer View simuliert werden: create view Lieferant as select L.LName, LAdr, Ware, Preis from LieferantAdr L, Angebot A where L.LName = A.LName 8

Schema-Zerlegung Anomalien entstehen durch Redundanzen Entwurfsziele: Vermeidung von Redundanzen Vermeidung von Anomalien evtl. Einbeziehung von Effizienzüberlegungen Vorgehen: Schrittweises Zerlegen des gegebenen Schemas (Normalisierung) in ein äquivalentes Schema ohne Redundanz und Anomalien Formalisierung von Redundanz und Anomalien: Funktionale Abhängigkeit 9

Funktionale Abhängigkeit (engl. Functional Dependency, FD) beschreibt Beziehungen zwischen den Attributen einer Relation Schränkt das Auftreten gleicher bzw. ungleicher Attributwerte innerhalb einer Relation ein spezielle Integritätsbedingung (nicht in SQL) Wiederholung Integritätsbedingungen in SQL: Primärschlüssel Fremdschlüssel (referenzielle Integrität) not null check 10

Wiederholung Schlüssel Definition: Eine Teilmenge S der Attribute eines Relationenschemas R heißt Schlüssel, wenn gilt: Eindeutigkeit Keine Ausprägung von R kann zwei verschiedene Tupel enthalten, die sich in allen Attributen von S gleichen. Minimalität Keine echte Teilmenge von S erfüllt bereits die Bedingung der Eindeutigkeit 11

Definition: funktional abhängig Gegeben: Ein Relationenschema R A, B: Zwei Mengen von Attributen von R (A,B R) Definition: B ist von A funktional abhängig (A B) gdw. für alle möglichen Ausprägungen von R gilt: Zu jedem Wert in A exist. genau ein Wert von B. Beispiel Lieferant (LName, LAdr, Ware, Preis): {LName} {LAdr} {LName, Ware} {LAdr} {LName, Ware} {Preis} üblicherweise schreibt man keine Klammern 12

Vergleich mit Schlüssel Gemeinsamkeiten zwischen dem Schlüssel im relationalen Modell und Funktionaler Abhängigkeit: Definitionen ähnlich Für alle Schlüsselkandidaten S = {A,B,...} gilt: Alle Attribute der Rel. sind von S funktional abhängig: {A,B,...} R Unterschied: Aber es gibt u.u. weitere funktionale Abhängigkeiten: Ein Attribut B kann z.b. auch funktional abhängig sein von Nicht-Schlüssel-Attributen von nur einem Teil des Schlüssels (nicht vom gesamten Schlüssel) FD ist Verallgemeinerung des Schlüssel-Konzepts 13

Vergleich mit Schlüssel Wie der Schlüssel ist auch die funktionale Abhängigkeit eine semantische Eigenschaft des Schemas: FD nicht aus aktueller DB-Ausprägung entscheidbar sondern muss für alle möglichen Ausprägungen gelten Triviale funktionale Abhängigkeit: Ein Attribut ist immer funktional abhängig: von sich selbst und von jeder Obermenge von sich selbst Solche Abhängigkeiten bezeichnet man als trivial 14

Partielle und volle FD Ist ein Attribut B funktional von A abhängig, dann auch von jeder Obermenge von A. Man ist interessiert, minimale Mengen zu finden, von denen B abhängt (vgl. Schlüsseldefinition) Definition: Gegeben: Eine funktionale Abhängigkeit A B Wenn es keine echte Teilmenge A A gibt, von der B ebenfalls funktional abhängt, dann heißt A B eine volle funktionale Abhängigkeit andernfalls eine partielle funktionale Abhängigkeit 15

Partielle und volle FD Beispiele: LName LAdr LName, Ware LAdr Ware? Preis LName, Ware Preis voll funktional abhängig partiell funktional abhängig nicht funktional abhängig voll funktional abhängig Prime Attribute Definition: Ein Attribut heißt prim, wenn es Teil eines Schlüsselkandidaten ist 16

Normalisierung In einem Relationenschema sollen also möglichst keine funktionalen Abhängigkeiten bestehen, außer vom gesamten Schlüssel Verschiedene Normalformen beseitigen unterschiedliche Arten von funktionalen Abhängigkeiten bzw. Redundanzen/Anomalien 1. Normalform 2. Normalform 3. Normalform Boyce-Codd-Normalform Herstellung einer Normalform durch verlustlose Zerlegung des Relationenschemas 17

1. Normalform Keine Einschränkung bezüglich der FDs Ein Relationenschema ist in erster Normalform, wenn alle Attributwerte atomar sind In relationalen Datenbanken sind nicht-atomare Attribute ohnehin nicht möglich Nicht-atomare Attribute z.b. durch group by A B C D 3 4 1 2 4 5 2 3 3 4 4 5 3 3 6 7 nested relation non first normal form In SQL nur temporär erlaubt 18

2. Normalform Motivation: Man möchte verhindern, dass Attribute nicht vom gesamten Schlüssel voll funktional abhängig sind, sondern nur von einem Teil davon. Beispiel: Lieferant ( LName, LAdr, Ware, Preis) Bäcker Ibk Brot 3,00 Bäcker Ibk Semmel 0,30 Bäcker Ibk Breze 0,40 Metzger Hall Filet 5,00 Metzger Hall Wurst 4,00 Konsequenz: In den abhängigen Attributen muss dieselbe Information immer wiederholt werden 19

2. Normalform Dies fordert man vorerst nur für Nicht-Schlüssel-Attribute (für die anderen z.t. schwieriger) Definition Ein Schema ist in zweiter Normalform, wenn jedes Attribut voll funktional abhängig von allen Schlüsselkandidaten oder prim ist Beobachtung: Zweite Normalform kann nur verletzt sein, wenn......ein Schlüssel(-Kandidat) zusammengesetzt ist 20

2. Normalform Zur Transformation in 2. Normalform spaltet man das Relationenschema auf: Attribute, die voll funktional abhängig vom Schlüssel sind, bleiben in der Ursprungsrelation R Für alle Abhängigkeiten A i B i von einem Teil eines Schlüssels (A i S) geht man folgendermaßen vor: Lösche die Attribute B i aus R Gruppiere die Abhängigkeiten nach gleichen linken Seiten A i Für jede Gruppe führe eine neue Relation ein mit allen enthaltenen Attributen aus A i und B i A i wird Schlüssel in der neuen Relation 21

Kapitel 3: Datenbanksysteme 2. Normalform Beispiel: Lieferant (LName, LAdr, Ware, Preis) Vorgehen: LAdr wird aus Lieferant gelöscht Gruppierung: Nur eine Gruppe mit LName auf der linken Seite es könnten aber noch weitere Attribute von LName abhängig sein (selbe Gruppe) es könnten Attribute von Ware abh. (2. Gruppe) Erzeugen einer Relation mit LName und LAdr Ergebnis: Lieferant LieferAdr (LName, Ware, Preis) (LName, LAdr) einzige partielle Abhängigkeit 22

Grafische Darstellung Schlüssel Schlüssel A A B (nach Heuer, Saake, Sattler) A B 23

3. Normalform Motivation: Man möchte zusätzlich verhindern, dass Attribute von nicht-primen Attributen funktional abhängen. Beispiel: Bestellung (AuftrNr, Datum, KName, KAdresse) 001 24.04.02 Meier Innsbruck 002 25.04.02 Meier Innsbruck 003 25.04.02 Huber Hall 004 25.04.02 Huber Hall 005 26.04.02 Huber Hall Redundanz: Kundenadresse mehrfach gespeichert Anomalien? 24

3. Normalform Abhängigkeit von Nicht-Schlüssel-Attribut bezeichnet man häufig auch als transitive Abhängigkeit vom Primärschlüssel weil Abhängigkeit über ein drittes Attribut besteht: AuftrNr KName KAdr Definition: Ein Relationenschema ist in 3. Normalform, wenn für jede nichttriviale Abhängigkeit X A gilt: X enthält einen Schlüsselkandidaten oder A ist prim Beobachtung: 2. Normalform ist mit impliziert 25

3. Normalform Transformation in 3. Normalform wie vorher Attribute, die voll funktional abhängig vom Schlüssel sind, und nicht abhängig von Nicht-Schlüssel-Attributen sind, bleiben in der Ursprungsrelation R Für alle Abhängigkeiten A i B i von einem Teil eines Schlüssels (A i S) oder von Nicht-Schlüssel-Attribut: Lösche die Attribute B i aus R Gruppiere die Abhängigkeiten nach gleichen linken Seiten A i Für jede Gruppe führe eine neue Relation ein mit allen enthaltenen Attributen aus A i und B i A i wird Schlüssel in der neuen Relation 26

Grafische Darstellung Schlüssel Schlüssel X X A (nach Heuer, Saake, Sattler) X A 27

Schlussbemerkungen Ein gut durchdachtes E/R-Diagramm liefert bereits weitgehend normalisierte Tabellen Normalisierung ist in gewisser Weise eine Alternative zum E/R-Diagramm Extrem-Ansatz: Universal Relation Assumption: Modelliere alles zunächst in einer Tabelle Ermittle die funktionalen Abhängigkeiten Zerlege das Relationenschema entsprechend (der letzte Schritt kann auch automatisiert werden: Synthesealgorithmus für die 3. Normalform) 28

Schlussbemerkungen Normalisierung kann schädlich für die Performanz sein, weil Joins sehr teuer auszuwerten sind Nicht jede FD berücksichtigen: Abhängigkeiten zw. Wohnort, Vorwahl, Postleitzahl Man kann SQL-Integritätsbedingungen formulieren, um Anomalien zu vermeiden (sog. Trigger) Aber es gibt auch Konzepte, Relationen so abzuspeichern, dass Join auf bestimmten Attributen unterstützt wird ORACLE-Cluster 29

Zusammenfassung Implikation 1. Normalform: Alle Attribute atomar 2. Normalform: Keine funktionale Abhängigkeit eines Nicht-Schlüssel- Attributs von Teil eines Schlüssels 3. Normalform: Zusätzlich keine nichttriviale funktionale Abhängigkeit eines Nicht-Schlüssel-Attributs von Nicht-Schlüssel- Attributen Boyce-Codd-Normalform: Zusätzlich keine nichttriviale funktionale Abhängigkeit unter den Schlüssel-Attributen 30