Relationenalgebra und SQL: Differenz
Bei der Operation R \ S werden aus der ersten Relation alle Tupel entfernt, die auch in der zweiten Relation vorhanden sind. Die Differenz (sowie die symmetrische Differenz) ist keine monotone Operation, daher ist auch die Relationale Algebra im Vergleich zu anderen deklarativen Anfragesprachen (z.B. Datalog) nicht monoton.
Definition
BearbeitenVoraussetzung
Bearbeiten- Vereinigungsverträglichkeit von R und S
Beispiel
Bearbeiten
|
|
|
In Worten: Ist das Tupel (123) aus R in der Relation S vorhanden?
- Wenn ja: Dann gehört das Tupel nicht zur Relation R\S.
- Wenn nein: Dann gehört das Tupel in die neue Relation R\S.
Danach gehe weiter zum nächsten Tupel von R mit der gleichen Prüfung.
SQL
BearbeitenSELECT * FROM R EXCEPT SELECT * FROM S;
alternativ:
SELECT * FROM R MINUS SELECT * FROM S;