<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.flbk-hamm.de/index.php?action=history&amp;feed=atom&amp;title=Relationale_Algebra</id>
	<title>Relationale Algebra - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.flbk-hamm.de/index.php?action=history&amp;feed=atom&amp;title=Relationale_Algebra"/>
	<link rel="alternate" type="text/html" href="https://wiki.flbk-hamm.de/index.php?title=Relationale_Algebra&amp;action=history"/>
	<updated>2026-05-06T21:58:28Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in FLBK-Wiki</subtitle>
	<generator>MediaWiki 1.45.3</generator>
	<entry>
		<id>https://wiki.flbk-hamm.de/index.php?title=Relationale_Algebra&amp;diff=2812&amp;oldid=prev</id>
		<title>Flbkwikiadmin: /* Einführung */</title>
		<link rel="alternate" type="text/html" href="https://wiki.flbk-hamm.de/index.php?title=Relationale_Algebra&amp;diff=2812&amp;oldid=prev"/>
		<updated>2026-04-17T09:38:59Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Einführung&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;de&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Nächstältere Version&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Version vom 17. April 2026, 11:38 Uhr&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l5&quot;&gt;Zeile 5:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Zeile 5:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Als Erfinder der relationalen Algebra gilt &amp;#039;&amp;#039;&amp;#039;Edgar F. Codd&amp;#039;&amp;#039;&amp;#039;. In den 1970er Jahren hat er mit dieser mathematischen Grundlage die Datenbankwelt revolutioniert. Die Datenbanksprache SEQUEL, ein Vorläufer des heutigen [[SQL]], war eine der ersten praktischen Umsetzungen der Ideen des relationalen Modells und damit der relationalen Algebra.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Als Erfinder der relationalen Algebra gilt &amp;#039;&amp;#039;&amp;#039;Edgar F. Codd&amp;#039;&amp;#039;&amp;#039;. In den 1970er Jahren hat er mit dieser mathematischen Grundlage die Datenbankwelt revolutioniert. Die Datenbanksprache SEQUEL, ein Vorläufer des heutigen [[SQL]], war eine der ersten praktischen Umsetzungen der Ideen des relationalen Modells und damit der relationalen Algebra.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;[[Datei:RelationMitarbeiter.png|mini]]&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Mengenoperationen ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== Mengenoperationen ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;

&lt;!-- diff cache key mediawiki:diff:1.41:old-2811:rev-2812:php=table --&gt;
&lt;/table&gt;</summary>
		<author><name>Flbkwikiadmin</name></author>
	</entry>
	<entry>
		<id>https://wiki.flbk-hamm.de/index.php?title=Relationale_Algebra&amp;diff=2811&amp;oldid=prev</id>
		<title>Flbkwikiadmin: Die Seite wurde neu angelegt: „== Einführung == Die &#039;&#039;&#039;relationale Algebra&#039;&#039;&#039; (auch Relationenalgebra genannt) bildet die theoretische Grundlage für Abfragesprachen in relationalen Datenbanken. In der Theorie der Datenbanken versteht man unter einer relationalen Algebra eine formale Sprache, mit der sich Abfragen über einem relationalen Schema formulieren lassen. Sie erlaubt es, Relationen miteinander zu verknüpfen und komplexere Informationen daraus herzu…“</title>
		<link rel="alternate" type="text/html" href="https://wiki.flbk-hamm.de/index.php?title=Relationale_Algebra&amp;diff=2811&amp;oldid=prev"/>
		<updated>2026-04-17T09:38:30Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „== Einführung == Die &amp;#039;&amp;#039;&amp;#039;relationale Algebra&amp;#039;&amp;#039;&amp;#039; (auch Relationenalgebra genannt) bildet die theoretische Grundlage für Abfragesprachen in &lt;a href=&quot;/index.php?title=Relationale_Datenbank&amp;amp;action=edit&amp;amp;redlink=1&quot; class=&quot;new&quot; title=&quot;Relationale Datenbank (Seite nicht vorhanden)&quot;&gt;relationalen Datenbanken&lt;/a&gt;. In der Theorie der Datenbanken versteht man unter einer relationalen Algebra eine formale Sprache, mit der sich Abfragen über einem relationalen Schema formulieren lassen. Sie erlaubt es, Relationen miteinander zu verknüpfen und komplexere Informationen daraus herzu…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== Einführung ==&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;relationale Algebra&amp;#039;&amp;#039;&amp;#039; (auch Relationenalgebra genannt) bildet die theoretische Grundlage für Abfragesprachen in [[Relationale Datenbank|relationalen Datenbanken]]. In der Theorie der Datenbanken versteht man unter einer relationalen Algebra eine formale Sprache, mit der sich Abfragen über einem relationalen Schema formulieren lassen. Sie erlaubt es, Relationen miteinander zu verknüpfen und komplexere Informationen daraus herzuleiten.&lt;br /&gt;
&lt;br /&gt;
Die relationale Algebra definiert Operationen, die sich auf eine Menge von Relationen anwenden lassen. Damit lassen sich beispielsweise Relationen verknüpfen, filtern oder umbenennen. Die Ergebnisse dieser Operationen sind immer wieder neue Relationen.&lt;br /&gt;
&lt;br /&gt;
Als Erfinder der relationalen Algebra gilt &amp;#039;&amp;#039;&amp;#039;Edgar F. Codd&amp;#039;&amp;#039;&amp;#039;. In den 1970er Jahren hat er mit dieser mathematischen Grundlage die Datenbankwelt revolutioniert. Die Datenbanksprache SEQUEL, ein Vorläufer des heutigen [[SQL]], war eine der ersten praktischen Umsetzungen der Ideen des relationalen Modells und damit der relationalen Algebra.&lt;br /&gt;
&lt;br /&gt;
== Mengenoperationen ==&lt;br /&gt;
Relationen bezeichnen Mengen im mathematischen Sinne. Eine Menge enthält sogenannte Tupel (Datensätze). Zwischen den Tupeln einer Menge bzw. Relation ist keine Ordnung (wie z. B. eine Reihenfolge) definiert. Auf Tabellen in der Praxis sind hingegen stets Ordnungen definiert, da es dort eine physische Reihenfolge der Datensätze gibt. &lt;br /&gt;
&lt;br /&gt;
Zudem kann ein Tupel in einer mathematischen Menge nicht mehrfach vorkommen – es gibt &amp;#039;&amp;#039;&amp;#039;keine Duplikate&amp;#039;&amp;#039;&amp;#039;. In einer reinen Datenbanktabelle wären Duplikate (ohne Primärschlüssel) hingegen technisch möglich. Auf diesen relationalen Mengen können unter gewissen Voraussetzungen die folgenden mathematischen Operationen ausgeführt werden.&lt;br /&gt;
&lt;br /&gt;
=== Vereinigungsverträglichkeit (Typkompatibilität) ===&lt;br /&gt;
Um Mengenoperationen auf Relationen durchführen zu können, müssen diese miteinander kompatibel sein. Die Typkompatibilität (auch &amp;#039;&amp;#039;&amp;#039;Vereinigungsverträglichkeit&amp;#039;&amp;#039;&amp;#039; genannt) zweier Relationen ist gegeben, wenn:&lt;br /&gt;
# sie den gleichen Grad haben (die Anzahl der Attribute/Spalten ist identisch).&lt;br /&gt;
# der Wertebereich (Datentyp) der korrespondierenden Attribute identisch ist.&lt;br /&gt;
&lt;br /&gt;
=== Vereinigung (Union) ===&lt;br /&gt;
[[Datei:MengeVereinigungsmenge.png|mini|rechts|Vereinigungsmenge]]&lt;br /&gt;
Ist die Vereinigungsverträglichkeit gegeben, können zwei Mengen vereinigt werden. Bei der Vereinigung von zwei Relationen &amp;lt;math&amp;gt;R \cup S&amp;lt;/math&amp;gt; werden alle Tupel der Relation R mit allen Tupeln der Relation S zu einer einzigen neuen Relation vereint. Duplikate, die in beiden Relationen vorkommen, werden bei der Vereinigung gelöscht.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Relation R enthält die Mitarbeiter {Müller, Meier}.&lt;br /&gt;
* Relation S enthält die Mitarbeiter {Meier, Schulze}.&lt;br /&gt;
* Die Vereinigung &amp;lt;math&amp;gt;R \cup S&amp;lt;/math&amp;gt; ergibt {Müller, Meier, Schulze}.&lt;br /&gt;
&lt;br /&gt;
=== Schnittmenge (Intersection) ===&lt;br /&gt;
[[Datei:MengeSchnittmenge.png|mini|rechts|Schnittmenge]]&lt;br /&gt;
Ist die Vereinigungsverträglichkeit gegeben, können zwei Mengen geschnitten werden. Die Schnittmenge &amp;lt;math&amp;gt;R \cap S&amp;lt;/math&amp;gt; beschreibt die Menge der Tupel, die sich exakt in &amp;#039;&amp;#039;&amp;#039;beiden&amp;#039;&amp;#039;&amp;#039; zu schneidenden Mengen wiederfinden.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Die Schnittmenge aus R {Müller, Meier} und S {Meier, Schulze} ist &amp;lt;math&amp;gt;R \cap S&amp;lt;/math&amp;gt; = {Meier}.&lt;br /&gt;
&lt;br /&gt;
=== Differenz (Difference) ===&lt;br /&gt;
[[Datei:MengeDifferenzmenge.png|mini|rechts|Differenzmenge]]&lt;br /&gt;
Die Differenz zweier Mengen kann gebildet werden, falls Vereinigungsverträglichkeit herrscht. Es wird eine Untermenge gebildet, die nur Elemente der einen Menge enthält, abzüglich der Elemente, die auch in der zweiten Menge vorkommen.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Die Differenz &amp;lt;math&amp;gt;R \setminus S&amp;lt;/math&amp;gt; (gesprochen: R ohne S) aus {Müller, Meier} und {Meier, Schulze} ergibt {Müller}.&lt;br /&gt;
&lt;br /&gt;
=== Symmetrische Differenz ===&lt;br /&gt;
Die symmetrische Differenz zweier Mengen kann gebildet werden, falls Vereinigungsverträglichkeit herrscht. Bei der symmetrischen Differenz handelt es sich um die Menge aller Tupel, die &amp;#039;&amp;#039;&amp;#039;entweder&amp;#039;&amp;#039;&amp;#039; in R &amp;#039;&amp;#039;&amp;#039;oder&amp;#039;&amp;#039;&amp;#039; in S, aber &amp;#039;&amp;#039;&amp;#039;nicht in beiden gleichzeitig&amp;#039;&amp;#039;&amp;#039; enthalten sind.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Die symmetrische Differenz aus R {Müller, Meier} und S {Meier, Schulze} ergibt {Müller, Schulze}.&lt;br /&gt;
&lt;br /&gt;
== Spezifische Relationenoperationen ==&lt;br /&gt;
&lt;br /&gt;
=== Kartesisches Produkt (Cross Product) ===&lt;br /&gt;
Ohne Voraussetzung bezüglich der Vereinigungsverträglichkeit lässt sich das Kartesische Produkt (&amp;lt;math&amp;gt;R \times S&amp;lt;/math&amp;gt;) zweier Mengen bilden. Das Resultat ist die Menge &amp;#039;&amp;#039;&amp;#039;aller möglichen Kombinationen&amp;#039;&amp;#039;&amp;#039; der Tupel aus R und S. Das heißt: Jedes Tupel der einen Relation wird mit jedem Tupel der anderen Relation kombiniert. &lt;br /&gt;
&lt;br /&gt;
Wenn alle Attribute verschieden sind, umfasst die Resultatsrelation die Summe der Attribute (Spalten) der Ausgangstabellen. Die Anzahl der Tupel (Zeilen) in der Resultatstabelle ist das Ergebnis der Multiplikation der Zeilenanzahlen der Ausgangstabellen (z. B. 3 Zeilen in R und 4 Zeilen in S ergeben 12 Zeilen im Kartesischen Produkt).&lt;br /&gt;
&lt;br /&gt;
=== Projektion ===&lt;br /&gt;
Die Projektion (&amp;lt;math&amp;gt;\pi&amp;lt;/math&amp;gt;) kann ohne Voraussetzungen durchgeführt werden. Sie extrahiert einzelne Attribute (Spalten) aus der ursprünglichen Attributmenge und ist somit als eine Art Filterung auf Spaltenebene zu verstehen. Die Projektion blendet also Spalten aus. Entstehen durch das Ausblenden von Spalten identische Zeilen, werden diese Duplikate in der Ergebnisrelation eliminiert.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039; Aus einer Mitarbeitertabelle mit {Personalnummer, Name, Abteilung} wird durch Projektion nur die Spalte {Abteilung} extrahiert. Das Ergebnis ist eine Liste aller Abteilungen ohne Duplikate.&lt;br /&gt;
&lt;br /&gt;
=== Selektion (Selection) ===&lt;br /&gt;
Die Selektion (&amp;lt;math&amp;gt;\sigma&amp;lt;/math&amp;gt;) kann ebenfalls ohne Voraussetzungen zur Kompatibilität mit anderen Tabellen durchgeführt werden, da sie nur auf einer Relation operiert. Sie extrahiert einzelne Tupel (Datensätze), die eine bestimmte Bedingung erfüllen, aus der ursprünglichen Relation. Sie ist somit als eine Art Filterung auf Zeilenebene zu verstehen (das heißt, die Selektion blendet Zeilen aus, die das Kriterium nicht erfüllen).&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Beispiel:&amp;#039;&amp;#039;&amp;#039; Aus einer Mitarbeitertabelle werden durch Selektion nur die Tupel extrahiert, bei denen das Attribut &amp;#039;&amp;#039;Gehalt &amp;gt; 3000&amp;#039;&amp;#039; ist.&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Datenbanken]]&lt;br /&gt;
[[Kategorie:AHR_I_Informatik LK]]&lt;br /&gt;
[[Kategorie:FI_I_SDM]]&lt;/div&gt;</summary>
		<author><name>Flbkwikiadmin</name></author>
	</entry>
</feed>