IMPLEMENTIERUNG VON OPERATIONEN AUF RELATIONEN
|
|
|
- Jonas Gerber
- vor 7 Jahren
- Abrufe
Transkript
1 Joins 1 Literatur IMPLEMENTIERUNG VON OPERATIONEN AUF RELATIONEN A. Kemper, A. Eickler: Datenbanksysteme Eine Einführung, 8. Auflage Oldenburg Verlag, 2011, ISBN (als E-Book mit dem Übungsbuch über die Informatik Bibliothek herunterladbar!) Kapitel 8 Priti Mishara, Maragaret H. Eich, Join Processing in Relational Databases, ACM Computing Surveys, Vol. 24, No. 1, March 1992 Goetz Graefe, Query Evaluation Techniques for Large Databases, ACM Computing Surveys, Vol. 25, No. 2, June 1993
2 Joins 2 Abfrage-Auswertungs-Techniken Effiziente Algorithmen für die Auswertung von komplexen Abfragen an große Datenbanken. Eine große Datenbank in diesem Zusammenhang ist eine Datei mit mehreren (hundert) Megabytes.
3 Joins 3 Abfrageverarbeitung in einem Datenbanksystem: Benutzerschnittstelle (User Interface) Abfragesprache Abfrageoptimierer Abfrageausführungs- Einheit Dateien und Indizes I/O Puffer Festplatten
4 Joins 4 Abfrageoptimierer (Query Optimizer) Der Optimierer übersetzt eine Anfrage (SQL) in eine Sequenz von Operationen, die in der Ausführungseinheit oder dem Dateisystem implementiert sind. Ziel ist es, einen Anfrage-Ausführungsplan (query execution plan) zu finden, der den Verbrauch von CPU, I/O, Speicher etc. minimiert. Ausführungseinheit Die Ausführungseinheit ist eine Sammlung von Funktionen und Mechanismen zur Kommunikation und Synchronisation zwischen Operatoren.
5 Joins 5 Schritte bei der Ausführung einer Abfrage Parsing Anfrage-Validierung (Schema-Katalog) Sichtengenerierung Optimierung Plan-Übersetzung Ausführung
6 Joins 6 Interaktive oder Eingebettete Anfragen (Cobol, PL/1, C, Fortran) Die Anfragebearbeitung konzentriert sich auf das Extrahieren von Informationen ohne Daten zu verändern. Für Updates siehe den Vorlesungsabschnitt über Transaktionen und ACID-Semantik. Atomic Consistent Isolated Durable
7 Joins 7 Anfragebearbeitung: Eingabe sind Relationen und Mengen Alle Implementierungen von Anfrage-Algorithmen iterieren über den Elementen der Eingabemengen. Mengen sind als Sequenzen verwirklicht. Algorithmen: Physische Algebra Systemspezifisch vs. Logische Algebra Datenmodell
8 Joins 8 Hersteller A Hersteller B Datenmodell logische Algebra physische Algebra physische Algebra Beispiel: Hersteller A: Nested-Loops Join Hersteller B: Nested-Loops Join & Merge Join
9 Joins 9 Spezifische Algorithmen (mit Kostenfunktion) sind nur physischen Operatoren zugeordnet, nicht aber logischen. Ein Ausdruck der logische Algebra ist nicht direkt ausführbar. Er muss in einen Ausdruck der physischen Algebra übersetzt werden.
10 Joins 10 Beispiel: {A} {B} Merge-Join (Schnitt) sortieren sortieren Scannen Datei A Scannen Datei B
11 Joins 11 Abbildung von logischen Operatoren auf physische Operatoren Diese Abbildung ist schwierig und komplex, denn... Einige Operatoren der physischen Algebra können mehrere logische Operatoren verwirklichen. Beispiel: Implementierung von Joins (gängige Implementierungen ermöglichen bereits eine Projektion für die Ausgabemenge, jedoch ohne Duplikat- Entfernung diese Art der Projektion nennt man auch Delta-Projektion) Einige physische Operatoren verwirklichen nur einen Teil eines logischen Operators. Beispiel: Ein Algorithmus, der Duplikate eliminiert verwirklicht nur einen Teil des relationalen Projektions- Operators.
12 Joins 12 Einige physische Operatoren existieren in der logischen Algebra überhaupt nicht. Beispiel: Sortieren. Einige Eigenschaften, die für logische Operatoren gelten, gelten nicht (oder nur teilweise) für physische Operatoren. Beispiel:, : Symmetrie und Kommutativität gelten (bezogen auf den Kostenfaktor) nicht, z.b. für Implementierung durch Nested-Loops.
13 Joins 13 Tupel, Relationen, Mengen + Relationale Algebra Physisches Datenbanken- Design Anfrageoptimierung Datentypen, Dateien, Sätze, Bytefelder + Low-Level Operationen
14 Joins 14 Kartesisches Produkt AB CD n AB n CD (Datensätze) Strategie: Lade so viele Blöcke von AB wie möglich in den Hauptspeicher und lasse dabei Platz für einen Block von BC. AB CD m Hauptspeicher-Blöcke
15 Joins 15 Kartesisches Produkt ABC DEF A B C , , , , , ,09 D E F 12 2,1 Peter 17 2,3 Meier A B C D E F , ,1 Peter , ,3 Meier , ,1 Peter , ,3 Meier , ,1 Peter , ,3 Meier , ,1 Peter , ,3 Meier , ,1 Peter , ,3 Meier , ,1 Peter , ,3 Meier
16 Joins 16 n, n : Sätze. AB CD b AB, b CD : Sätze/Block. m : Anzahl der Blöcke im Hauptspeicher. Anzahl der Block-Zugriffe um AB zu lesen: n AB b AB. CD muss n m AB 1 - mal gelesen werden. b AB Jedes Mal werden dazu n CD bcd Zugriffe benötigt. Anzahl der Block-Zugriffe: n b AB AB n AB m 1 b AB n b CD CD n b AB AB 1 n m 1 CD bcd
17 Joins 17 Beispiel: n b AB AB n b m 100 CD CD Anzahl der Zugriffe = Bei 20 Block-Zugriffen pro Sekunde wird dieses kartesische Produkt ca. 35 Minuten benötigen. Wähle AB als die Relation, mit dem kleineren Quotienten n bab AB. Das heißt, die Relation, die in weniger Blocks passt.
18 Joins 18 IMPLEMENTIERUNG VON JOINS Gegeben sei folgende Abfrage: A B C D AB CD 99 Nach den, in Teil 1 der Vorlesung behandelten, Verfahren kann man diesen relationalen Ausdruck zunächst so umformen: AB A BC D99 CD Durch Ersetzen des kartesischen Produktes durch einen natürlichen Verbund ergibt sich folgende optimierte Abfrage: A AB BC D 99 CD
19 Joins 19 A AB BC D 99 CD Wie kann diese Abfrage implementiert werden? 1.,, oder 2.,, ist besser wenn CD: Index(D) dann ist d=99 (CD) schnell. sonst Scanne CD (einmal) mit n b CD CD Blockzugriffen { Menge von Tupeln aus CD mit D=99 }
20 Joins 20 Beispiel: nab = ncd = bab = bcd = 5 m = 100 (Hauptspeicher) ABCB: Blockzugriffe bei 20 Blocks/sec 35 Minuten Wenn aber die Selektion vorher ausgeführt wird: n b CD CD = C D 99 D 99 CD nur dieser Teil ist von Interesse!
21 Joins 21 Die Menge von C-Werten wird verglichen mit einer Menge von B-Werten (AB) wenn # C-Werte klein (passt in den Hauptspeicher) AB hat einen Index(B) dann benötigt AB CD 99 wenige Blockzugriffe. BC D wenn # C-Werte klein, kein Index dann Scanne AB (einmal) mit n b AB AB = Blockzugriffen = ,5 Minuten vs. AB x CD = Minuten Umformen der Abfrage!!
22 Joins 22 Bisherige Annahme: Ergebnis paßt in den Hauptspeicher Jetzt: AB CD BC AB und CD passen nicht in den Hauptspeicher Implementierungsstrategien (Join) Nested-Loops Join Sort-Merge Join Hash Join
23 Joins 23 Generelle Strategien (physikalisch) Vorverarbeitung der Dateien z.b. - Sortieren, - Erzeugen von Indizes. Berechnung von Optionen vor der Ausführung z.b. AB BC n b AB AB vs. n b CD CD
24 Joins 24 Nested-Loops Join AB CD R S BC r a s b {,,,,, } äußere innere Für jedes Tupel der äußeren Relation werden alle Tupel der inneren Relation gelesen und verglichen. s S do { r R do { if r(a) s(b) then r s Speichern in Q } } -- Einfachste Methode -- Effizienz: Die innere Relation sollte die mit der größeren Kardinalität sein.
25 Joins 25 Nested Loops Nested Blocks Da Sätze immer nur in ganzen Blöcken gelesen werden können, liegt folgende Optimierung nahe: äußere innere Rocking der inneren Relation äußere innere
26 Joins 26 Performanz: O n m Anwendung: Unpassend für sehr große Relationen Gut für parallele Implementierung (Hardware Datenbankmaschinen)
27 Joins 27 Sort-Merge Join Schritt 1: Sortiere AB, Sortiere CD. Schritt 2: Vergleiche & Mische n b AB AB n b CD CD AB CD BC Falls B und C Schlüssel: read 1 st Tuple R read 1 st Tuple S r do { while s(c) < r(b) read next s S; if r(b) = s(c) then join r and s store in Q }
28 Joins 28 Falls die Join-Attribute keine Schlüssel sind, dann kann ein Wert mehr als einmal vorkommen, deshalb können mehrere Durchläufe der inneren Relation notwendig sein. R r(b) S s(c) r1 X X s1 r2 X X s2 X s3 Modifiziere den Algorithmus so, dass er den letzten Wert r(b) und den Punkt in S, an dem der letzte innere Loop begann, speichert. Immer wenn ein doppelter (mehrfacher) r(b)-wert erkannt wird, wird die Schleife an dem vorherigen Startpunkt in S neu begonnen.
29 Joins 29 A B s C D AB AC CD A B C D
30 Joins 30 Hauptvorteil: Die Anzahl der Vergleiche zwischen Tupeln wird reduziert. Performanz: Wenn die Relationen bereits sortiert vorliegen, ist der Algorithmus besser als Nested-Loop. Jede Relation wird nur einmal gelesen. Die Ausführungszeit wird durch Sortieren und Mischen beschränkt. Sortieren: Onlog n
31 Joins 31 HASHED JOIN METHODE Idee: Versuche die Tupel der ersten Relation zu isolieren, die zu einem gegebenen Tupel der zweiten Relation unter der Joinbedingung passen.
32 Joins 32 SIMPLE HASH JOIN Erste Relation: Die Werte der Join-Attribute der ersten Relation werden mittels einer Hashfunktion gehashed. h(v) Hashtabelle Inhalt: 1. Tupel, oder 2. TID, Schlüssel Buckets Buckets
33 Joins 33 2-te Relation: Für jedes Tupel der zweiten Relation werden die Join- Attribute mit der selben Hashfunktion gehashed. Wenn die Werte auf ein nicht leeres Bucket gehashed werden, dann werden die entsprechenden Tupel miteinander verglichen.
34 Joins 34 Simple Hash r s r. As. B Algorithmus: u s do { Hashe über den Join-Attributen u.b; stelle die Tupel in die Hashtabelle entsprechend den gehashten Werten; } t r do { Hashe über den Join-Attributen t.a; if t auf ein nicht-leeres Bucket hashed then if t.a = u.b then result := result (t x u) }
35 Joins 35 A B s C D 1 D1 7 D2 8 D3 11 D4 AB AC CD A B C D D D2
36 Joins 36 C D 1 D1 7 D2 8 D3 11 D4 0 = v mod 5 h(v) 1 1, D1 11, D4 A B h(v) = v mod Bucket directory 7, D2 8, D3 A B C D D D2
37 Joins 37 Die Hashtabelle wird üblicherweise für die kleinere der beiden Relationen angelegt. Performanz: Hash-basierte Joins sind die effektivsten Join-Techniken. Komplexität: O n m da beide Relationen nur einmal gelesen werden. Die Geschwindigkeit hängt von der Hashfunktion ab. Hash-Kollisionen vermindern die Performanz! Jedes Tupel, dass auf ein nicht-leeres Bucket hashed, muss überprüft werden, ob es der Join-Bedingung genügt. Falls die Join-Bedingung = ist, ist die Implementierung schwierig! Die Eliminierung von Duplikaten in der Ergebnismenge ist schwierig.
38 Joins 38 WAHL DES AUSFÜHRUNGSPLANS select r.a, s.b, t.d from r, s, t where r.a = s.a and s.b = t.c; sei: r(a,f) s(a,b,c) t(c,d,e) r r. A, s. B, t. D r. As. A s. Bt. C s s t r. A, s. B, t. D s. Bt. C r. As. A t r
39 Joins 39 select * from employee2 e2, employee e, department d where e2.lastname = e.lastname and d.deptno = e.workdept;
40 Joins 40 r s t Die Reihenfolge der Joins ist durch den Optimierer hier wählbar! Möglichst sollte zuerst der Join ausgeführt werden, der das kleinste Ergebnis liefert! Doch Wie lässt sich die Größe eines Joins abschätzen?
41 Joins 41 Selectivity Factor Der Selectivity Factor (Join Selection Factor) gibt die Prozent der Tupel an, die bei einem Join verbunden werden (im Verhältnis zum kartesischen Produktes). Selectivity Factor klein Nested Loop schlecht Hashed Join besser groß Nested Loop Hashed Join oder besser! Partitioned Hash Join besser Frage: Wie kann der Selectivity Factor bestimmt werden?
42 Joins 42 r( R) s( S) Nutze die Katalog Informationen: Falls R S = entspricht dem Kartesischen Produkt Falls R S ein Schlüssel von r ist, können die Tupel aus s höchstens mit einem Tupel aus r übereinstimmen. Die Tupelanzahl des Join-Ergebnisses entspricht also höchstens der Anzahl von Tupeln in s. Falls R S ein Fremdschlüssel von r ist, so ist die Tupelanzahl des Join-Ergebnisses exakt der Anzahl von Tupeln in s. Falls R S weder Schlüssel von r noch von s ist, ist das Abschätzen schwer (aufwendig). Übliche Verfahren sind: o parametrisierte Verteilungen, o Histogramme und o Stichproben.
43 Joins 43 Stichprobenverfahren Es wird eine zufällige Menge von Tupeln einer Relation gezogen und deren Verteilung als repräsentativ für die ganze Relation angesehen. Das Lesen der Tupel erfordert jedoch teure Zugriffe auf den Hintergrundspeicher.
44 Joins 44 Übersicht Nested-Loops Join O(n x m) o mit Nested-Blocks o mit Roching Sort-Merge Join O(n log n) Hash Join o Simple Hash Join O(n + m) o Hash-Partitioned Join Grace Hash Join O((n + m) / K) K Speicherblöcken und 2K Prozessoren
45 Joins 45
46 Joins 46 Literatur: A. Kemper, A. Eickler: Datenbanksysteme Eine Einführung, 8. Auflage Oldenburg Verlag, 2011, ISBN (als E-Book mit dem Übungsbuch über die Informatik Bibliothek herunterladbar!) Kapitel 8 Query Evaluation Techniques for Large Databases S. Graefe ACM Computing Survey, Vol. 25, No. 2, Juni 1993 Join Processing in Relational Databases P. Mishra, M. H. Eich ACM Computing Survey, Vol. 24, No. 1, März 1992
IMPLEMENTIERUNG VON OPERATIONEN AUF RELATIONEN
Joins 1 IMPLEMENTIERUNG VON OPERATIONEN AUF RELATIONEN Literatur Priti Mishara, Maragaret H. Eich, Join Processing in Relational Databases, ACM Computing Surveys, Vol. 24, No. 1, March 1992 Goetz Graefe,
Anfragebearbeitung 2. Vorlesung Datenbanksysteme vom
Vorlesung Datenbanksysteme vom 21.11.2016 Anfragebearbeitung 2 Architektur eines DBMS Logische Optimierung Physische Optimierung Kostenmodelle + Tuning Physische Optimierung Iterator: einheitliche Schnittstelle
Kapitel 10: Relationale Anfragebearbeitung
Ludwig Maimilians Universität München Institut für Informatik Lehr- und Forschungseinheit für Datenbanksysteme Skript zur Vorlesung Wintersemester 201/2016 Kapitel 10: Relationale Anfragebearbeitung Vorlesung:
Indexstrukturen in SQL
Indestrukturen in SQL Anlegen eines Primärinde in SQL: Anlegen eines Sekundärinde in SQL: Bsp: create table Dozenten ( DNr integer primary key, Name varchar(0), Geburt date, ) create [Unique] inde indename
Kapitel 6 Externes Sortieren
Kapitel 6 Externes Sortieren Überblick Two-Way Merge Sort External Merge Sort Kostenminimierung B+ Bäume zur Sortierung 1 Architektur und Implementierung von Datenbanksystemen WS 2009/10 Melanie Herschel
Übung Datenbanksysteme II Anfrageausführung. Thorsten Papenbrock
Übung Datenbanksysteme II Anfrageausführung Thorsten Papenbrock Einleitung: Themen 3 Iterator-Operatoren Algorithmen-Klassen ort-basierte Hash-basierte Index-basierte Algorithmen-chwierigkeitsgrade One-Pass-Algorithmen
Anfrageoptimierung Kostenabschätzung
Institute for Web Science & Technologies WeST Grundlagen der Datenbanken Kostenabschätzung Dr. Thomas Gottron Wintersemester 2012/13 Regel vs. Kostenbasierte Optimierung Bisher: Regeln, wie Optimierung
Universität Augsburg, Institut für Informatik Wintersemester 2008/2009 Prof. Dr. W. Kießling 03. Februar Semesterklausur
Universität Augsburg, Institut für Informatik Wintersemester 2008/2009 Prof. Dr. W. Kießling 03. Februar 2009 Dr. A. Huhn, M. Endres, T. Preisinger Datenbanksysteme I Semesterklausur Hinweise: Die Bearbeitungszeit
5. Basisalgorithmen für DB-Operationen
5. Basisalgorithmen für DB-Operationen Datenbankparameter Komplexität von Grundalgorithmen Unäre Operationen (Scan, Selektion, Projektion) Binäre Operationen: Mengenoperationen Berechnung von Verbunden
FachPraktikum 1590 Erweiterbare Datenbanksysteme. Aufgaben Phase 1
FachPraktikum 1590 Erweiterbare Datenbanksysteme Aufgaben Phase 1 Wintersemester 2004/2005 Ralf Hartmut Güting, Dirk Ansorge, Thomas Behr, Markus Spiekermann Praktische Informatik IV, Fernuniversität Hagen
Star Join & Kostenbasierte Optimierung. Architektur von Datenbanksystemen II
Star Join & Kostenbasierte Optimierung Architektur von Datenbanksystemen II Star Join Übungsaufgabe zum 09.06.2015 JOIN-ALGORITHMUS für folgendes Scenario Große Faktentabelle F mit sehr vielen Einträgen
Datenbanksysteme I Anfragebearbeitung und -optimierung. 27.6.2011 Felix Naumann
Datenbanksysteme I Anfragebearbeitung und -optimierung 27.6.2011 Felix Naumann Anfragebearbeitung Grundproblem 2 Anfragen sind deklarativ. SQL, Relationale Algebra Anfragen müssen in ausführbare (prozedurale)
Anfragebearbeitung. Kapitel 7. Anfragebearbeitung 285 / 520
Kapitel 7 Anfragebearbeitung 285 / 520 Übersicht Anfrage Übersetzer Ausführungsplan Laufzeitsystem Ergebnis 286 / 520 Übersetzung Übersetzung SQL ist deklarativ, irgendwann muß Anfrage aber für Laufzeitsystem
Anfrageverarbeitung. Einführung
Anfrageverarbeitung Prof. Dr. T. Kudraß 1 Einführung Wir betrachten die Implementierung der Operatoren der Relationenalgebra: Basis-Operationen: Selektion ( σ ) Auswahl einer Teilmenge von Tupeln aus der
Anfrageoptimierung Logische Optimierung
Institute for Web Science & Technologies WeST Grundlagen der Datenbanken Logische Optimierung Dr. Thomas Gottron Wintersemester 2012/13 Ablauf der Deklarative Anfrage Scanner Parser Sichtenauflösung Algebraischer
Anfragebearbeitung. Anfrage. Übersetzer. Ausführungsplan. Laufzeitsystem. Ergebnis
Anfragebearbeitung Anfrage Übersetzer Ausführungsplan Laufzeitsystem Ergebnis Übersetzung SQL ist deklarativ, Übersetzung für Laufzeitsystem in etwas prozedurales DBMS übersetzt SQL in eine interne Darstellung
Oracle 9i Einführung Performance Tuning
Kurs Oracle 9i Einführung Performance Tuning Teil 3 Der Optimizer Timo Meyer Wintersemester 2005 / 2006 Seite 1 von 16 Seite 1 von 16 1. auf Tabellen 2. 3. Optimizer 4. Optimizer RBO 5. Optimizer CBO 6.
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof Alfons Kemper, PhD Blatt Nr 2 Übung zur Vorlesung Grundlagen: Datenbanken im WS5/6 Harald Lang, Linnea Passing (gdb@intumde) http://www-dbintumde/teaching/ws56/grundlagen/
Einleitung Projektion Selektion Join Mengenop. Vollst.keit. Einleitung Projektion. Selektion Join. Vollst.keit. Einleitung Projektion Selektion Join
Parsen der Anfrage (SQL) Transformation in eine Standardform (Relationenalgebra) Logische Optimierung Transformation in alternative Zugriffspläne, Physische Optimierung Ausführung des gewählten Zugriffsplans
Webbasierte Informationssysteme
SS 2004 Prof. Dr. Stefan Böttcher Universität Paderborn - SS 2004 - Prof. Dr. Stefan Böttcher Folie 1 Was ist eine relationale Datenbank? Menge von Relationen (=Tabellen) und Constraints (=Integritätsbedingungen)
Grundlagen: Datenbanken
Grundlagen: Datenbanken 3. Zentralübung / Fragestunde Linnea Passing Harald Lang [email protected] Diese Folien finden Sie online. Die Mitschrift stellen wir im Anschluss online. Agenda Hinweise zur Klausur
Hash-Join Algorithmen
Hash-Join lgorithmen dvanced Topics in Databases Ws08/09 atthias ichly Einleitung 2 Grundlage ist das Paper: Join Processing in Database Systems With Large ain emories Quelle: C Transactions on Database
Datenbanken. Seminararbeit. Einführung in das wissenschaftliche Arbeiten
Seminararbeit vorgelegt von: Gutachter: Studienbereich: Christian Lechner Dr. Georg Moser Informatik Datum: 6. Juni 2013 Inhaltsverzeichnis Inhaltsverzeichnis 1 Einführung in Datenbanken 1 1.1 Motivation....................................
Query Languages (QL) Relationale Abfragesprachen/Relational
Relationale Algebra Relationale Abfragesprachen/Relational Query Languages (QL) Abfragesprachen: Daten aus einer Datenbank zu manipulieren und abzufragen (retrieve information) Das relationalle Modell
Anfragebearbeitung 3
Anfragebearbeitung 3 VL Datenbanksysteme, WS 2014/5 Reinhard Pichler Arbeitsbereich Datenbanken und Artificial Intelligence Institut für Informationssysteme Technische Universität Wien Kostenmodelle und
Aggregatfunktionen in der Relationenalgebra?
Aggregatfunktionen in der Relationenalgebra? Dieter Sosna Aggregatfunktionen in der Relationenalgebra p.1/23 Gliederung Motivation Begriffe Definitionen Anwendungen Zusammenfassung Aggregatfunktionen in
Kap. 3 Relationenmodell mit relationaler Algebra
Kap. 3 Relationenmodell mit relationaler Algebra Kap. 3.1. Trägermenge Seien D 1, D 2,..., D k Domänen: (Typen, Arten, Sorten, Wertmengen) z.b. string integer real Boolean DateTime BLOB, TIFF-image, HTML-Doc,
B*-BÄUME. Ein Index ist seinerseits wieder nichts anderes als eine Datei mit unpinned Records.
B*-Bäume 1 B*-BÄUME Beobachtung: Ein Index ist seinerseits wieder nichts anderes als eine Datei mit unpinned Records. Es gibt keinen Grund, warum man nicht einen Index über einem Index haben sollte, und
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Dr. Thomas Neumann
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Dr. Thomas Neumann Blatt Nr. 9 Übung zur Vorlesung Grundlagen: Datenbanken im WS4/5 Harald Lang ([email protected]) http://www-db.in.tum.de/teaching/ws45/grundlagen/
Datenbanken Grundlagen und Design
Frank Geisler Datenbanken Grundlagen und Design 3., aktualisierte und erweiterte Auflage mitp Vorwort 15 Teil I Grundlagen 19 i Einführung in das Thema Datenbanken 21 i.i Warum ist Datenbankdesign wichtig?
Raumbezogene Datenbanken (Spatial Databases)
Raumbezogene Datenbanken (Spatial Databases) Ein Vortrag von Dominik Trinter Alexander Christian 1 Inhalte Was ist ein raumbezogenes DBMS? Modellierung Abfragen Werkzeuge zur Implementierung Systemarchitektur
Datenbanken: Architektur & Komponenten 3-Ebenen-Architektur
Datenbanken: Architektur & Komponenten 3-Ebenen-Architektur Moderne Datenbanksysteme sind nach der 3-Ebenen-Architektur gebaut: Anwendung 1 Web-Anwendung Anwendung 2 Java-Programm... Anwendung n Applikation
Kapitel 1: Einführung 1.1 Datenbanken?
1. Einführung 1.1. Datenbanken? Seite 1 Kapitel 1: Einführung 1.1 Datenbanken? 1. Einführung 1.1. Datenbanken? Seite 2 Willkommen! Studierenden-Datenbank Hans Eifrig hat die Matrikelnummer 1223. Seine
Informatik II, SS 2014
Informatik II SS 2014 (Algorithmen & Datenstrukturen) Vorlesung 7 (21.5.2014) Binäre Suche, Hashtabellen I Algorithmen und Komplexität Abstrakte Datentypen : Dictionary Dictionary: (auch: Maps, assoziative
Algorithmen II Vorlesung am
Algorithmen II Vorlesung am 31.01.2013 Algorithmen für externen Speicher INSTITUT FÜR THEORETISCHE INFORMATIK PROF. DR. DOROTHEA WAGNER KIT Universität des Landes Baden-Württemberg und Algorithmen nationales
Kapitel 8: Physischer Datenbankentwurf
8. Physischer Datenbankentwurf Seite 1 Kapitel 8: Physischer Datenbankentwurf Speicherung und Verwaltung der Relationen einer relationalen Datenbank so, dass eine möglichst große Effizienz der einzelnen
Datenbankoptimierung
Datenbankoptimierung Lehrveranstaltung Datenbanktechnologien Prof. Dr. Ingo Claßen Prof. Dr. Martin Kempa Hochschule für Technik und Wirtschaft Berlin Hardware c Ingo Claßen, Martin Kempa Architektur:
Kapitel 12: Schnelles Bestimmen der Frequent Itemsets
Einleitung In welchen Situationen ist Apriori teuer, und warum? Kapitel 12: Schnelles Bestimmen der Frequent Itemsets Data Warehousing und Mining 1 Data Warehousing und Mining 2 Schnelles Identifizieren
Datenbank- Implementierungstechniken
Vorlesung Datenbank- Implementierungstechniken Universität Magdeburg, WS 02/03 Kai-Uwe Sattler [email protected] VL Datenbank-Implementierungstechniken 0 1 Überblick 1. Aufgaben und Prinzipien
Inhaltsverzeichnis Vorwort zur vierten Auflage Vorwort zur dritten Auflage Vorwort zur zweiten Auflage Vorwort zur ersten Auflage Hinweise zur CD
Vorwort zur vierten Auflage 11 Vorwort zur dritten Auflage 13 Vorwort zur zweiten Auflage 15 Vorwort zur ersten Auflage 17 Hinweise zur CD 19 1 Datenbanken und Datenbanksysteme 21 1.1 Zentralisierung der
Aufbau Datenbanksysteme
Aufbau Datenbanksysteme Lehrveranstaltung Datenbanktechnologien Prof. Dr. Ingo Claßen Prof. Dr. Martin Kempa Hochschule für Technik und Wirtschaft Berlin Speichersystem c Ingo Claßen, Martin Kempa Softwarearchitektur
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D. Blatt Nr. 10 Übung zur Vorlesung Grundlagen: Datenbanken im WS15/16 Harald Lang, Linnea Passing ([email protected])
DATENBANKEN SQL UND SQLITE VON MELANIE SCHLIEBENER
DATENBANKEN SQL UND SQLITE VON MELANIE SCHLIEBENER INHALTSVERZEICHNIS 1. Datenbanken 2. SQL 1.1 Sinn und Zweck 1.2 Definition 1.3 Modelle 1.4 Relationales Datenbankmodell 2.1 Definition 2.2 Befehle 3.
Inhaltsverzeichnis. Lothar Piepmeyer. Grundkurs Datenbanksysteme. Von den Konzepten bis zur Anwendungsentwicklung ISBN:
Lothar Piepmeyer Grundkurs Datenbanksysteme Von den Konzepten bis zur Anwendungsentwicklung ISBN: 978-3-446-42354-1 Weitere Informationen oder Bestellungen unter http://www.hanser.de/978-3-446-42354-1
IBM Informix Tuning und Monitoring
Seminarunterlage Version: 11.01 Copyright Version 11.01 vom 25. Juli 2012 Dieses Dokument wird durch die veröffentlicht. Copyright. Alle Rechte vorbehalten. Alle Produkt- und Dienstleistungs-Bezeichnungen
Listener: Bei Oracle erfolgt die Steuerung (konventionell) via listener.ora (Listener Konfiguration), tnsnames.ora (Client Konfiguration)
Protokoll 1: Listener: Bei Oracle erfolgt die Steuerung (konventionell) via listener.ora (Listener Konfiguration), tnsnames.ora (Client Konfiguration) Abschnitt 2.1 (Ausführungen zum Shutdown / Startup)
OPERATIONEN AUF EINER DATENBANK
Einführung 1 OPERATIONEN AUF EINER DATENBANK Ein Benutzer stellt eine Anfrage: Die Benutzer einer Datenbank können meist sowohl interaktiv als auch über Anwendungen Anfragen an eine Datenbank stellen:
Abschluss Einblick und Ausblick
Abschluss Einblick und Ausblick Prof. Dr. T. Kudraß 1 Benutzer Komponenten eines DBMS (Überblick) I/O-Prozessor Output-Generierung Parser für selbst. oder eingebettete Kommandos Precompiler Autorisierungs-Kontrolle
Wir haben folgende Ausprägung der Relation Studenten:
Übungen Aufgabe Wir haben folgende Ausprägung der Relation Studenten: SID Name Email Age Note 2833 Jones [email protected] 9 9 2877 Smith [email protected] 2 8 2976 Jones [email protected] 2
Grundlagen von Datenbanken
Agenda: Grundlagen von Datenbanken SS 2010 3. Relationale Algebra Prof. Dr. Stefan Böttcher Universität Paderborn mit Material von Prof. Dr. Gregor Engels Grundlagen von Datenbanken - SS 2010 - Prof. Dr.
! DBMS organisiert die Daten so, dass minimal viele Plattenzugriffe nötig sind.
Unterschiede von DBMS und files Speichern von Daten! DBMS unterstützt viele Benutzer, die gleichzeitig auf dieselben Daten zugreifen concurrency control.! DBMS speichert mehr Daten als in den Hauptspeicher
4. Anfrageoptimierung. 4.1. Optimierung einzelner Operationen
Es gibt zwei Stufen für die Optimierung einer SELECT-FROM-WHERE-Anfrageauswertung: a) Optimierung jeder einzelnen Operation => systematische Schätzung der Kosten versch. Ausführungsstrategien, Auswahl
Es geht also im die SQL Data Manipulation Language.
1 In diesem Abschnitt wollen wir uns mit den SQL Befehlen beschäftigen, mit denen wir Inhalte in Tabellen ( Zeilen) einfügen nach Tabelleninhalten suchen die Inhalte ändern und ggf. auch löschen können.
Garten - Daten Bank. - survival pack -
Garten - Daten Bank - survival pack - Dr. Karsten Tolle PRG2 SS 2017 Inhalt heute Kurz: Motivation und Begriffe SQL (survival pack) create table (Tabelle erzeugen) insert into (Einfügen) select (Anfragen)
2.5 Relationale Algebra
2.5 Relationale Algebra 2.5.1 Überblick Codd-vollständige relationale Sprachen Relationale Algebra Abfragen werden durch exakte Angabe der auf den Relationen durchzuführenden Operationen formuliert Relationenkalküle
Datenbanken: Indexe. Motivation und Konzepte
Datenbanken: Indexe Motivation und Konzepte Motivation Warum sind Indexstrukturen überhaupt wünschenswert? Bei Anfrageverarbeitung werden Tupel aller beteiligter Relationen nacheinander in den Hauptspeicher
Hash-Verfahren. Einführung
Hash-Verfahren Prof. Dr. T. Kudraß 1 Einführung Drei Alternativen, wie Dateneinträge k* im Index aussehen können: 1. Datensatz mit Schlüsselwert k.
Hash-Verfahren. Prof. Dr. T. Kudraß 1
Hash-Verfahren Prof. Dr. T. Kudraß 1 Einführung Drei Alternativen, wie Dateneinträge k* im Index aussehen können: 1. Datensatz mit Schlüsselwert k.
Datenbanken und SQL. Springer Vieweg. Eine praxisorientierte Einführung mit Anwendungen in Oracle, SQL Server und MySQL.
Edwin Schicker Datenbanken und SQL Eine praxisorientierte Einführung mit Anwendungen in Oracle, SQL Server und MySQL 4., überarbeitete Auflage Springer Vieweg Inhaltsverzeichnis 1 Übersicht über Datenbanken
Rückblick: Datenbankentwurf
Rückblick: Datenbankentwurf Entity-Relationship-Modell für konzeptuellen Entwurf Entitytypen (entity types) (z.b. Studenten) Beziehungstypen (relationships) (z.b. hören) Attribute beschreiben Gegenstände
Aufgabe 1 Indexstrukturen
8. Übung zur Vorlesung Datenbanken im Sommersemester 2006 mit Musterlösungen Prof. Dr. Gerd Stumme, Dr. Andreas Hotho, Dipl.-Inform. Christoph Schmitz 25. Juni 2006 Aufgabe 1 Indexstrukturen Zeichnen Sie
Relationale Algebra. Relationale Algebra. Grenzen der Ausdrucksstärke konjunktiver Anfragen. Vereinigung und Differenz.
4.1 4.2 4.1 4.2 NICOLE SCHWEIKARDT, ISOLDE ADLER GOETHE-UNIVERSITÄT FRANKFURT VORLESUNG LOGIK UND DATENBANKEN KAPITEL 4, SEITE 1 Grenzen der Ausdrucksstärke konjunktiver Anfragen Wir haben gesehen: konjunktive
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D.
TU München, Fakultät für Informatik Lehrstuhl III: Datenbanksysteme Prof. Alfons Kemper, Ph.D. Blatt Nr. 07 Übung zur Vorlesung Grundlagen: Datenbanken im WS15/16 Harald Lang, Linnea Passing ([email protected])
Das relationale Datenmodell
Das relationale Datenmodell Konzepte Attribute, Relationenschemata, Datenbank-Schemata Konsistenzbedingungen Beispiel-Datenbank Seite 1 Einführung Zweck datenmäßige Darstellung von Objekten und Beziehungen
XAMPP-Systeme. Teil 3: My SQL. PGP II/05 MySQL
XAMPP-Systeme Teil 3: My SQL Daten Eine Wesenseigenschaft von Menschen ist es, Informationen, in welcher Form sie auch immer auftreten, zu ordnen, zu klassifizieren und in strukturierter Form abzulegen.
Fachpraktikum 1590 Erweiterbare Datenbanksysteme. Aufgaben Phase 1
Fachpraktikum 1590 Erweiterbare Datenbanksysteme Aufgaben Phase 1 Wintersemester 2014/2015 Ralf Hartmut Güting, Dirk Ansorge, Thomas Behr, Christian Düntgen, Simone Jandt, Markus Spiekermann Lehrgebiet
Schlüssel. Definition: Ein Schlüssel (key) einer Relation r(r) ist eine Til Teilmenge K von R, so dass für je zwei verschiedene Tupeln t 1
Schlüssel Definition: Ein Schlüssel (key) einer Relation r(r) ist eine Til Teilmenge K von R, so dass für je zwei verschiedene Tupeln t 1 und t 2 r gilt: - t 1 (K) t 2 (K) und - keine echte Teilmenge K'
Informatik II Prüfungsvorbereitungskurs
Informatik II Prüfungsvorbereitungskurs Tag 4, 9.6.2017 Giuseppe Accaputo [email protected] 1 Aufbau des PVK Tag 1: Java Teil 1 Tag 2: Java Teil 2 Tag 3: Algorithmen & Komplexität Tag 4: Dynamische Datenstrukturen,
Relationale Datenbanken
Ramon A. Mata-Toledo, Pauline K. Cushman Relationale Datenbanken Schaum's Repetitorien Übersetzung aus dem Amerikanischen von G&U Technische Dokumentation GmbH Z Die Autoren 9 Vorwort 9 1 Ein Überblick
Datenmodelle und Datenbanken 2
Datenmodelle und Datenbanken 2 Prof. N. Fuhr Institut für Informatik und Interaktive Systeme Arbeitsgruppe Informationssysteme 24. Februar 2005 Hinweise zur Bearbeitung Die Zeit läuft erst, wenn Sie alle
