270 likes | 403 Views
Folienadaption HS, 4/00. Relationen sind Tabellen!. Relationales Modell = Tabellarische Repräsentation der Daten + „assoziative“ Anfragesprache. Datenbank enthält auch Beschreibung der Daten: Datenbankschema ( also Meta daten). Oft andere Notation!. Wie kommt man zu einem DB-Schema?.
E N D
Relationen sind Tabellen! Relationales Modell = Tabellarische Repräsentation der Daten + „assoziative“ Anfragesprache Datenbank enthält auch Beschreibung der Daten: Datenbankschema ( also Metadaten)
Oft andere Notation! Wie kommt man zu einem DB-Schema? • 1. Datenmodellierung • typisch: Entity-Relationship-Modell (datenorientiert) • zunehmend mit den Operationen (Unified Modeling Language, UML) Lies z.B: einem Kunde (customer) werden Lieferungen (shipments) gesandt, keine, eine oder mehrere (1:M) Kardinalitäten sind Invarianten: eine Lieferung kann nie an mehrere Kunden gehen
Schlüssel (key) Allgemein: eine identifizierende Folge von Attributen. (Invanrianzeigenschaft!) Beispiel zu Entity-Relationship-Modellierung KDnr (ownerID) First name Nachname kauft Kunden (AntiqueOwners) N Handelstransaktion (Antiques) verkauft bestellen (Orders) M Antiquität Was? (item (siehe Tutorial S. 6 u. 7)
CREATE TABLE ORDERS (OWNERID INTEGER NOT NULL FOREIGN KEY REFERENCES AntiqueOwners (OWNERID), ITEMDESIRED CHAR(40) NOT NULL); CREATE TABLE AntiqueOwners (OWNERID INTEGER NOT NULL, OwnerLastname CHAR(40) NOT NULL, OwnerFirstName CHAR(30)); CREATE TABLE Antiques (SellerID INTEGER NOT NULL FOREIGN KEY REFERENCES AntiqueOwners (OWNERID), .....); Wie kommt man zum DB-Schema: Datendefinition 2. Datenbankschema definieren im RDM heißt das: Tabellenstruktur festlegen, Bezeichner, Attribute und deren Typ, ggf. Invarianten
Das Datenbänkchen... ... benutzen wir später!
Leider hat diese Tabelle des Tutorials herzlich wenig mit der ersten zu tun! Was fehlt da? Eine zweite DB für einfache SQL-Anfragen
EBNF-Syntax Metasymbole! Ein SQL-Ausdruck braucht also kein (Selektions-)prädikat So sollte Ergebnis aussehen, (leider) werden Duplikate nicht entfernt Einfache SQL-Anfragen Grundstruktur (eine beteiligte Tabelle): SELECT [<attributBezeicher>] | *FROM <tabellenBezeichner >[WHERE <prädikat>] ; Ergebnis einer Anfrage ist immer eine Tabelle! ... auf der wieder eine Anfrage... -> Algebra auf Relationen als theoretische Basis. Relationenalgebra: eine applikative Sprache SELECT STATE FROM EmployeeAddressTable;
SELECT FirstName, LastName, Address, City, State FROM EmployeeAddressTable; Projektion SELECT LastName, Address, City, State FROM EmployeeAddressTable WHERE State = ´Ohio´; Selektion Zeichenkettenwerte in Hochkommata Beispiele
Selektionsprädikate (1) Engl. <condition_list> <prädikat> This is a boolean expression which each row must satisfy. Operators which may be used include AND, OR, NOT, >, >=, =, <, <= The LIKE operator permits strings to be compared using 'wild cards'. The symbols _ and % are used to represent a single character or a sequence of characters. The IN operator allows an item to be tested against a list of values. There is a BETWEEN operator for checking ranges.
Kann hier auch OR stehen? Einfache Anfragen (1) Programmierer, die weniger als 4000 (was??) verdienen? SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE SALARY < 40000 AND POSITION = ´Programmer´; Angestellte mit Gehalt > 40000 oder Bonus (benefits) von mehr als 10000? SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE SALARY < 40000 OR BENEFITS > 10000;
SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE POSITION IN ( ´Manager´, ´Programmer´, ´Staff´, ´Engineer´) ; Vermeidet lästiges OR, was bedeutet: NOT IN ? Einfache Anfragen (2) Manager mit Gehalt > 40000 oder Bonus (benefits) von mehr als 10000? SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE POSITION = ´Manager´ AND (SALARY < 40000 OR BENEFITS > 10000; Manager, Programmierer, Stabsmitglieder oder Ingenieure!
Natürlich nur, wenn die Attribute gleichen Typ haben! Einfache Anfragen (3) Manager mit Gehalt zwischen 50000000 und 100000000 ? SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE POSITION = ´MANAGER´ AND SALARY BETWEEN 50000000 AND 100000000 ; Manager mit Gehalt < Bonus (benefits) ? SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE POSITION = ´Manager´ AND SALARY < BENEFITS ;
SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE POSITION = ´MANAGER´ AND SALARY BETWEEN 50000000 AND 100000000 ; Etwas ´verbose´ ! SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE LASTNAME LIKE ´S%´; In regulären Ausdrücken ist das der * Einfache Anfragen (4) Manager mit Gehalt zwischen 50000000 und 100000000 ? Angestellte mit Anfangsbuchstabe ´S´
Diese Subqueries sind unabhängig voneinander Einfache Subqueries Personen mit Vornamen, die auch als Nachnamen auftauchen SELECT EMPLOYEEIDNO FROM EMPLOYEESTATISTICSTABLEWHERE FIRSTNAME IN (SELECT LASTNAME FROM EMPLOYEESTATISTICSTABLE) ; Beachte Unterschied zu ´Vorname = Nachname´
Alias manchmal nötig, immer nützlich SELECT LASTNAME FROM EMPLOYEESTATISTICSTABLE ES, EMPLOYEEADDRESSTABLE EAWHERE POSITION = ´MANAGER´ AND SALARY > 1000000 AND EA.EMPLOYEENO = ES.EMPLOYEENO; Verbund (genauer: Gleichheitsverbund) Mehrere Tabellen Anfrage: Namen der Manager, die mehr als 1000000 verdienen. Problem: Verbindung zwischen der Information in verschiedenen Tabellen kann nicht hergestellt werden. Annahme:EmployeeAddressTablebesitzt zusätzlich SpalteEmployeeNo
Andere Jointypen Voriges Beispiel: Join-Prädikat Teil der WHERE-Klausel: muss nicht so sein. Unterschied: Gültigkeitsbereich der Bezeichner in WHERE - Klausel SELECT LASTNAME FROM EMPLOYEESTATISTICSTABLE ES JOIN EMPLOYEEADDRESSTABLE EA ON EA.EMPLOYEENO = ES.EMPLOYEENO WHERE POSITION = ´MANAGER´ AND SALARY > 1000000;
Natürlicher Verbund Gleichverbund (Equijoin) auf gleich benannten Attributen verschiedener Tabellen. SELECT LASTNAME FROM EMPLOYEESTATISTICSTABLE ES NATURAL JOIN EMPLOYEEADDRESSTABLE EA WHERE POSITION = ´MANAGER´ AND SALARY > 1000000;
Erstelle Liste aller Namen und Adressen und (ggf.) des Gehalts SELECT EA.LASTNAME, EA.ADRESS,ES.SALARY FROM EMPLOYEESTATISTICSTABLE ES RIGHT OUTERJOIN EMPLOYEEADDRESSTABLE EA ON EA.EMPLOYEENO = ES.EMPLOYEENO ; ID 010 400 Right Outer Join: auch die Tupel des rechten Relationsarguments ohne Korrespondenzwert im ersten gehören zum Ergebnis! Äusserer Verbund Wo bleibt die Adresse der nicht angestellten Personen?
SELECT STATE FROM EmployeeAddressTable; liefert .... Mehrfach auftretende Werte (Duplikate) unterdrücken durch Schlüsselwort DISTINCT . SELECT DISTINCT STATE FROM EmployeeAddressTable ORDER BY State; hier sogar sortiert Duplikate eliminieren
Aggregierungsfunktionen · SUM () gives the total of all the rows, satisfying any conditions, of the given column, where the given column is numeric. · AVG () gives the average of the given column. · MAX () gives the largest figure in the given column. · MIN () gives the smallest figure in the given column. · COUNT(*) gives the number of rows satisfying the conditions. Bsp:Gehaltssumme und -durchschnitt aller Mitarbeiter! SELECT SUM(SALARY), AVG(SALARY) FROM EMPLOYEESTATISTICSTABLE;
Zielliste und Prädikate können Arithmetik enthalten Bsp:Angestellte, die das Doppelte des Durchschnitts verdienen Arithmetisch SELECT EMPLOYEEID FROM EMPLOYEESTATISTICSTABLE WHERE SALARY > (SELECT AVG(SALARY) FROM EMPLOYEESTATISTICSTABLE);
Gruppierung Maximaler Verdienst aller Berufsgruppen SELECT POSITION MAX(SALARY) FROM EMPLOYEESTATISTICSTABLE GROUP BY POSITION; Maximaler Verdienst aller Berufsgruppen mit Durchschnittsgehalt > 50000 SELECT POSITION MAX(SALARY) FROM EMPLOYEESTATISTICSTABLE GROUP BY POSITIONHAVING AVG(SALARY) > 50000;
Daten Ändern Adding Data To insert rows into a table, do the following: INSERT INTO ANTIQUES VALUES (21, 01, 'Ottoman', 200.00); This inserts the data into the table, as a new row, column-by-column, in the pre-defined order. Instead, let's change the order and leave Price blank: INSERT INTO ANTIQUES (BUYERID, SELLERID, ITEM) VALUES (01, 21, 'Ottoman');
Beliebige Prädikate möglich Ändern und Löschen Ändere Preis für alle Positionen ´chair´ auf 500. UPDATE ANTIQUES SET PRICE = 500.00 WHERE ITEM = 'Chair'; Lösche alle Ottomanen DELETE FROM ANTIQUES WHERE ITEM = 'Ottoman';
SELECT COUNT(LASTNAME) FROM MONEYMAKERS GROUPBY CITY, STATE; Anfrage auf VIEW Nochmal: Datendefinition Mit Hilfe von Anfragen können Tabellen definiert werden, die künftig(fast) wie Basistabellen behandelt werden. Diese Tabellen heißen VIEW . Sie werden normalerweise nicht materialisiert. CREATE VIEW MONEYMAKERS ASSELECT LASTNAME, CITY, STATE FROM EMPLOYEESTATISTICSTABLE ES, EMPLOYEEADDRESSTABLE EAWHERE SALARY > 1000000 AND EA.EMPLOYEENO = ES.EMPLOYEENO;
Nullwert != 0 NULL : undefiniert Schemaänderungen erleichtern Rapid Prototyping Hinzufügen des Attributs (der Spalte) EMPLOYEENO zur EMPLOYEEADDRESSTABLE ALTER TABLE EMPLOYEEADDRESSTABLE ADD (EMPLOYEENO INTEGER NULL); Nicht behandelt: Mengenoperationen, physikalisches Schema, Einbettung in Pogrammiersprachen.