Speicherung und Verwaltung von Daten besteht aus Datenbanken und Datenbankmanagementsystem (DBMS) Datenbank: strukturiert abgelegte Daten zu verwaltende Daten, z.B. Adressen Datenbankschema: Metadaten zur Datenbankdefinition Datenbankmanagementsystem: Software zur Verwaltung der Daten Datenbank definieren, erzeugen, manipulieren K. Puschke MySQL
Datenbankserver Anwendung, Client Anwendungslogik und Darstellung/Benutzeroberfläche Drei-Schichten-Architektur Datenbankserver Anwendung (Anwendungslogik) Webserver oder Anwendungsserver (Darstellung) Browser oder Client des Anwendugnsservers K. Puschke MySQL
eingebettet in anderen Anwendungen schwedische Firma MySQL AB, jetzt Sun Microsystems, Übernahme durch Oracle kostenlose Community-Version, freie Software (GPL) kostenpflichtige Enterprise-Version K. Puschke MySQL
zeigt alle Datenbanken USE datenbank wählt Datenbank datenbank aus SHOW TABLES zeigt Tabellen der gewählten Datenbank DESCRIBE tabelle zeigt Spalten der Tabelle an K. Puschke MySQL
Angabe von Spalte(n) und Tabellen, die auszugeben sind * bedeutet alle Spalten der Tabelle SELECT Name,Vorname FROM KundInnen SELECT * FROM KundInnen ORDER BY sortiert Ausgabe SELECT Name,Vorname FROM KundInnen ORDER BY Name K. Puschke MySQL
die Zahl der ausgegeben Einträge häufig mit ORDER BY kombiniert SELECT Name,Vorname FROM KundInnen LIMIT 5 NULL Kein Eintrag (z.B. für Kundin Müller keine Telefonnummer vermerkt): NULL NULL NULL ist etwas anderes als die Zahl Null oder ein leerer String! K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Datenbankdesign 7 Einführung in die theoretischen Grundlagen Datenbankmodell Datenbankschema 8 Datenbankdesign in der Praxis 9 Qualitätssicherung 10 Datenbank definieren K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Datenbankmodell Konzept zur Beschreibung der Struktur einer Datenbank konzeptionelles Modell: formale Beschreibung eines Teils der Realität K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Konzeptionelles Modell formale Beschreibung eines Ausschnittes der Realität verbreitet: Entity-Relationship-Model (Gegenstand-Beziehungs-Modell) K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Datenbankmodell Konzept zur Beschreibung der Struktur einer Datenbank konzeptionelles Modell: formale Beschreibung eines Teils der Realität logisches Modell: Beschreibung der Implementierung K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Logisches Modell Beschreibung der Implementierung verbreitete Modelle: netzwerkartig hierarchisch relational objektorientiert objektrelational ... K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Relationales Modell E.F. Codd (1970) hohe Verbreitung seit den 80er Jahren, z.B. MySQL PostgreSQL Oracle . . . Datenbank als Sammlung von Relationen (Tabellen) Relation: Menge von Tupeln (Datensätzen, Zeilen) unsortiert keine Duplikate Schema einer Relation (Tabellenstruktur) besteht aus Attributen (Spalten) K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Datenbankmodell Konzept zur Beschreibung der Struktur einer Datenbank konzeptionelles Modell: formale Beschreibung eines Teils der Realität logisches Modell: Beschreibung der Implementierung physisches Modell: Datenspeicherung, Zugriffspfade K. Puschke MySQL
Datenbank definieren Datenbankmodell Datenbankschema Physisches Modell Wie werden die Daten gespeichert? Auf Platte geschrieben oder nur im Speicher gehalten? Wie auf Dateien aufgeteilt? Was für Dateien? Indizierung K. Puschke MySQL
Datenbank definieren Ablauf Konzeptionelles Design: Entity-Relationship-Model Logisches Design: Relationales Schema Physisches Design: Storage Engine Erstellen von ER-Diagrammen Softwaretools Dia Microsoft Visio MySQL Workbench . . . K. Puschke MySQL
Datenbank definieren Ablauf Konzeptionelles Design: Entity-Relationship-Model Logisches Design: Relationales Schema Physisches Design: Storage Engine Elemente eines ER-Diagramms Entität: Rechteck Attribut: Kreis Beziehung: Raute Primärschlüssel: unterstrichen Kardinaliäten: Chen-Notation: 1 oder N Min-Max-Notation: Paare mit Einträgen 0,1 oder N, z.B. (1,N) K. Puschke MySQL
Datenbank definieren Ablauf Konzeptionelles Design: Entity-Relationship-Model Logisches Design: Relationales Schema Physisches Design: Storage Engine Vom ER-Diagramm zum Relationalen Schema ein Primärschlüssel für jede Tabelle eine Tabelle für jede Entität eine Tabelle für jede n-m-Beziehung Attribute sind Spalten der jeweiligen Tabelle n-eins-Beziehung als Fremdschlüssel (in der Tabelle der Entität auf der n-Seite) K. Puschke MySQL
Datenbank definieren Ablauf Konzeptionelles Design: Entity-Relationship-Model Logisches Design: Relationales Schema Physisches Design: Storage Engine Storage Engine Physisches Schema zuständig für Datenspeicherung setzt physisches Modell um MySQL bringt mehrere Storage Engines mit weitere Engines können eingebunden werden Standard Engine in MySQL: MyISAM Index Sequential Access Method zunehmend verbreitet: InnoDB wir verwenden die Standardeinstellungen K. Puschke MySQL
Datenbank definieren Normalform Datenbankdesign 7 Einführung in die theoretischen Grundlagen 8 Datenbankdesign in der Praxis 9 Qualitätssicherung Normalform 10 Datenbank definieren K. Puschke MySQL
Datenbank definieren Normalform Normalform Normalform Jedes Attribut, das kein Schlüssel ist, hängt direkt vom Schlüssel ab, vom gesamten Schlüssel, und zwar nur vom Schlüssel K. Puschke MySQL
Datenbank definieren Normalform Daten in Normalform keine Anomalien Konsistenz der Daten keine Redundanzen einfache Wartung effizientes Suchen und Bearbeiten K. Puschke MySQL
Datenbank definieren Normalform Normalisierung Normalisierung = in Normalform bringen verschiedene Algorithmen ER-Diagramme und daraus abgeleitete relationale Schemata: häufig schon in Normalform ggf. “nachbessern” K. Puschke MySQL
Datenbank definieren Normalform Normalform Hinweis Die Darstellung zum Thema Normalisierung/Normalform ist sehr vereinfacht. Wer mehr wissen möchte, findet links im Wiki. K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Datenbankdesign 7 Einführung in die theoretischen Grundlagen 8 Datenbankdesign in der Praxis 9 Qualitätssicherung 10 Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Umgang mit der MySQL-Doku eckige Klammern umschliessen optionale Klauseln | bedeutet oder nur eine der genannten Alternativen kann/muss benutzt werden geschweifte Klammern: eine der Alternativen muss benutzt werden eckige Klammern: eine oder keine der Alternativen kann benutzt werden Beispiel 1: DROP TABLE [IF EXISTS] tbl_name Beispiel 2: {DESCRIBE | DESC} tbl_name [col_name | wild]} K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Datenbank definieren Tabellen anlegen Name der Tabelle Storage Engine Beschreibung der Spalten Name der Spalte Datentyp (INT Integer, VARCHAR(20) String mit max. 20 Zeichen) Eintrag obligatorisch? (NULL/NOT NULL) Eintrag eindeutig? (UNIQUE) Schlüssel? (PRIMARY KEY, impliziert NOT NULL und UNIQUE) Default-Wert? (DEFAULT) Extras? (z.B. AUTO_INCREMENT; AUTO_INCREMENT ist kein Standard-SQL!) K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Tabellen verwalten I Tabelle anlegen CREATE TABLE CREATE TABLE KundInnen (KundNr INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(50) NOT NULL, Vorname VARCHAR(25)) K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Tabellen verwalten II Informationen über Tabellen DESCRIBE und SHOW CREATE TABLE DESCRIBE KundInnen SHOW CREATE TABLE KundInnen K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Tabellen verwalten III Tabellenstruktur ändern ALTER TABLE ALTER TABLE KundInnen DROP COLUMN Vorname . . . ALTER TABLE Vorsicht! Viele Stolperfallen! K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Tabellen verwalten IV Tabellen löschen DROP TABLE DROP TABLE KundInnen K. Puschke MySQL
Datenbank definieren Exkurs: Die MySQL-Dokumentation Tabellen anlegen Aufgaben Datenbank definieren CREATE TABLE, DROP TABLE, SHOW CREATE TABLE K. Puschke MySQL
Data Manipulation Language (DML) Daten abfragen und verändern Data Control Language (DCL) Zugriffsrechte Data Administration Language (DAL) finetuning, Zugriffspfad K. Puschke MySQL
DBMS beinhaltet DDL, DML, DCL, DAL deklarative Sprache beschreibt, was zu tun ist, nicht wie erweitert um prozedurale Funktionalitäten (Ablaufsteuerung) Konvention: Befehle und Co. in Großbuchstaben schreiben SELECT * FROM kurse K. Puschke MySQL
u.v.a. fast alle Systeme implementieren nicht den kompletten Standard implementieren eigene Erweiterungen daher: Kompatibilität der Systeme eingeschränkt K. Puschke MySQL
SQL Objekt: Tabelle, Spalte,. . . kein Objekt im Sinne von OO-Programmierung! Deskriptor: identifiziert das Objekt (z.B. Spaltenname) unterschiedlich für die verschiedenen Datenbanksystem K. Puschke MySQL
MySQL Vollständig Tabelle: Datenbank.Tabelle Spalte: Datenbank.Tabelle.Spalte Abkürzung Angabe der Datenbank kann entfallen, wenn die mit USE voreingestellte benutzt werden soll Angabe der Tabelle kann zusätzlich entfallen, wenn Spaltenname innerhalb der verwendeten Tabellen eindeutig K. Puschke MySQL
über mehrere Tabellen Tabellen verknüpfen (JOIN) verknüpfe Zeilen, ggf. gemäß einer Bedingung (an gemeinsame Attribute) über verknüpften Tabellen SELECT durchführen K. Puschke MySQL
Cartesisches Produkt KundNr Name Vorname KundNr ArtikelNr 1 Example Erna 1 4 1 Example Erna 2 5 1 Example Erna 2 6 2 Kundin Karla 2 6 2 Kundin Karla 2 5 2 Kundin Karla 2 6 K. Puschke MySQL
Verknüpfungsbedingung: KundInnen.KundNr = Bestellungen.KundNr KundNr Name Vorname KundNr ArtikelNr 1 Example Erna 1 4 2 Kundin Karla 2 5 2 Kundin Karla 2 6 K. Puschke MySQL
ohne Entsprechung in der anderen Tabelle entfallen SELECT Name, Vorname, ArtikelNr FROM KundInnen INNER JOIN Bestellungen ON KundInnen.KundNr = Bestellungen.KundNr K. Puschke MySQL
ohne Entsprechung in der anderen Tabelle werden mit NULL-Einträgen ergänzt LEFT JOIN: alle Zeilen der linken Tabelle, dazu nur Zeilen der rechten Tabelle, die eine Entsprechung in der linken Tabelle haben SELECT Name, Vorname, ArtikelNr FROM KundInnen INNER JOIN Bestellungen ON KundInnen.KundNr = Bestellungen.KundNr zeigt auch KundInnen, die nichts bestellt haben K. Puschke MySQL
Datenbanksystemen Vor- und Nachteile von Datenbanken 15 Datenbanken vs. Dateien Vorteile von Datenbanksystemen Nachteile von Datenbanksystemen 16 Relationale Datenbanksysteme K. Puschke MySQL
Datenbanksystemen Vorteile von Datenbanksystemen Daten und Datenstruktur enthalten Datenstruktur als Metadaten im DBS gespeichert konkurrierende, gleichzeitige Zugriffe handhaben Fehlertoleranz Sicherheit (Zugriffsschutz) und Flexibilität durch Trennung von Anwendung und Daten große Datenmengen beherrschbar K. Puschke MySQL
Datenbanksystemen Trennung von Anwendung und Daten Externe Sichten Trennung von physischer Ebene, logischer Ebene und externer Ebene (Sicht) Sicht: user-abhängige Zugriffsmöglichkeit und Präsentation der Daten Beispiel: Zugriffsschutz Beispiel: Prüfungsbüro hat Zugriff auf andere Daten als Studierendenverwaltung angepaßte Präsentation der Daten kleinere Änderung auf einer Ebene beeinflußt andere Ebenen nicht K. Puschke MySQL
Datenbanksystemen Nachteile von Datenbanksystemen nicht alle Datenbanksysteme bieten die genannten Vorteile Aufwand nicht immer gerechtfertigt insbesondere unterschiedliche Sichten aufwändig Beherrschbarkeit großer Datenmengen verleitet zu ausufernder Datensammlung oder Verknüpfung von Daten Mißachtung des Datenschutzes, insbesondere der gebotenen Datensparsamkeit drängt sich u.U. auf K. Puschke MySQL
nachträgliche Änderung des Schemas problematisch gut geeignet für stark strukturierte Daten z.B. Adressdaten weniger geeignet für flexible Strukturen z.B. user generated content nicht für verteilte Systeme optimiert hohe Verbreitung auch in diesen Bereichen lange Zeit quasi alternativlos K. Puschke MySQL
SELECT COUNT(*) FROM KundInnen WHERE Stadt=’WIEN’ liefert Anzahl der KundInnen aus Wien SUM,AVG,MAX,MIN Summe, Durchschnitt, Maximum, Minimum SELECT SUM(Rechnungsbetrag) FROM Rechnungen K. Puschke MySQL
mit gemeinsamem Attributwert aggregieren SELECT Name, COUNT(*) FROM KundInnen gibt aus, wieviele KundInnen jeweils den gleichen Nachnamen haben HAVING schränkt Ergebnisse ein SELECT Name, COUNT(*) FROM KundInnen HAVING COUNT(*) > 1 zeigt nur Namen, die mehrfach vorkommen K. Puschke MySQL
stellt Bedingungen an die Spalten, die in die Berechnung eingehen HAVING stellt Bedingungen an die Ergebnisse der Berechnung Spalten Keine Spalten in SELECT und HAVING eintragen, die nicht in GROUP BY stehen! K. Puschke MySQL