LogischeOperatoren-SQL: Unterschied zwischen den Versionen

Aus FI-Wiki
Keine Bearbeitungszusammenfassung
Markierung: Zurückgesetzt
 
(4 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 1: Zeile 1:
== Logische Operatoren in SQL ==
[[SQL]] bietet verschiedene '''logische Operatoren''', um Bedingungen zu verknüpfen und Werte zu vergleichen. Sie werden vor allem in der '''WHERE'''-Klausel verwendet.


SQL bietet verschiedene logische Operatoren, um Bedingungen zu verknüpfen und Werte zu vergleichen. Sie werden vor allem in der `WHERE`-Klausel verwendet.
== AND – Beide Bedingungen müssen wahr sein ==
 
=== AND – Beide Bedingungen müssen wahr sein ===


<syntaxhighlight lang="sql">
<syntaxhighlight lang="sql">
Zeile 12: Zeile 10:
Gibt alle Kunden aus, die in '''Deutschland''' und in '''Berlin''' wohnen.
Gibt alle Kunden aus, die in '''Deutschland''' und in '''Berlin''' wohnen.


=== OR – Mindestens eine Bedingung muss wahr sein CCC===
== OR – Mindestens eine Bedingung muss wahr sein ==


<syntaxhighlight lang="sql">
<syntaxhighlight lang="sql">
Zeile 21: Zeile 19:
Gibt alle Kunden aus, die entweder aus '''Deutschland''' oder '''Österreich''' kommen.
Gibt alle Kunden aus, die entweder aus '''Deutschland''' oder '''Österreich''' kommen.


=== NOT – Bedingung muss '''nicht''' wahr sein ===
== NOT – Bedingung muss '''nicht''' wahr sein ==


<syntaxhighlight lang="sql">
<syntaxhighlight lang="sql">
Zeile 30: Zeile 28:
Gibt alle Kunden aus, die '''nicht''' aus Deutschland sind.
Gibt alle Kunden aus, die '''nicht''' aus Deutschland sind.


=== LIKE – Mustervergleich mit Wildcards ===
== LIKE – Mustervergleich mit Wildcards ==


Wird verwendet, um Zeichenfolgen anhand eines Musters zu filtern.   
Wird verwendet, um Zeichenfolgen anhand eines Musters zu filtern.   
Zeile 58: Zeile 56:
Gibt Kunden zurück, deren zweiter Buchstabe ein '''a''' ist.
Gibt Kunden zurück, deren zweiter Buchstabe ein '''a''' ist.


=== Kombination von LIKE mit AND/OR ===
== Kombination von LIKE mit AND/OR ==


<syntaxhighlight lang="sql">
<syntaxhighlight lang="sql">
Zeile 74: Zeile 72:
WHERE preis BETWEEN 10 AND 100;
WHERE preis BETWEEN 10 AND 100;
</syntaxhighlight>
</syntaxhighlight>


== IN – Wert in Liste enthalten ==  
== IN – Wert in Liste enthalten ==  

Aktuelle Version vom 28. Januar 2026, 14:37 Uhr

SQL bietet verschiedene logische Operatoren, um Bedingungen zu verknüpfen und Werte zu vergleichen. Sie werden vor allem in der WHERE-Klausel verwendet.

AND – Beide Bedingungen müssen wahr sein

SELECT * FROM kunden
WHERE land = 'Deutschland' AND stadt = 'Berlin';

Gibt alle Kunden aus, die in Deutschland und in Berlin wohnen.

OR – Mindestens eine Bedingung muss wahr sein

SELECT * FROM kunden
WHERE land = 'Deutschland' OR land = 'Österreich';

Gibt alle Kunden aus, die entweder aus Deutschland oder Österreich kommen.

NOT – Bedingung muss nicht wahr sein

SELECT * FROM kunden
WHERE NOT land = 'Deutschland';

Gibt alle Kunden aus, die nicht aus Deutschland sind.

LIKE – Mustervergleich mit Wildcards

Wird verwendet, um Zeichenfolgen anhand eines Musters zu filtern. Zwei wichtige Platzhalter:

  • % – Beliebig viele Zeichen
  • _ – Genau ein Zeichen
SELECT * FROM kunden
WHERE name LIKE 'A%';

Gibt alle Kunden zurück, deren Name mit A beginnt (z. B. Anna).

SELECT * FROM kunden
WHERE name LIKE '%er';

Gibt Kunden zurück, deren Name mit er endet (z. B. Müller).

SELECT * FROM kunden
WHERE name LIKE '_a%';

Gibt Kunden zurück, deren zweiter Buchstabe ein a ist.

Kombination von LIKE mit AND/OR

SELECT * FROM kunden
WHERE name LIKE 'A%' AND stadt = 'Berlin';

Gibt alle Kunden, deren Name mit A beginnt und die in Berlin wohnen.

BETWEEN – Bereichsabfrage

Prüft, ob ein Wert innerhalb eines geschlossenen Bereichs liegt (inklusive Grenzen).

SELECT * FROM produkte
WHERE preis BETWEEN 10 AND 100;

IN – Wert in Liste enthalten

Prüft, ob ein Wert in einer gegebenen Liste vorkommt.

SELECT * FROM kunden
WHERE land IN ('Deutschland', 'Österreich', 'Schweiz');

IS NULL / IS NOT NULL – Null-Werte prüfen

NULL ist ein spezieller Wert für „kein Inhalt“. Man vergleicht ihn nicht mit =, sondern mit IS.

SELECT * FROM kunden
WHERE telefon IS NULL;
SELECT * FROM kunden
WHERE telefon IS NOT NULL;