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.

Differenzmenge

Definition Bearbeiten

 

Voraussetzung Bearbeiten

  • Vereinigungsverträglichkeit von R und S

Beispiel Bearbeiten

R:
A B C
1 2 3
4 5 6
S:
A B C
7 8 9
4 5 6
R \ S:
A B C
1 2 3

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 Bearbeiten

SELECT * FROM R 
EXCEPT
SELECT * FROM S;

alternativ:

SELECT * FROM R 
MINUS
SELECT * FROM S;