SQLite - LIKE-Klausel
SQLite LIKEDer Operator wird verwendet, um Textwerte mithilfe von Platzhaltern mit einem Muster abzugleichen. Wenn der Suchausdruck mit dem Musterausdruck abgeglichen werden kann, gibt der LIKE-Operator true zurück (1). In Verbindung mit dem LIKE-Operator werden zwei Platzhalter verwendet.
- Das Prozentzeichen (%)
- Der Unterstrich (_)
Das Prozentzeichen steht für null, eins oder mehrere Zahlen oder Zeichen. Der Unterstrich steht für eine einzelne Zahl oder ein einzelnes Zeichen. Diese Symbole können in Kombinationen verwendet werden.
Syntax
Es folgt die grundlegende Syntax von% und _.
SELECT FROM table_name
WHERE column LIKE 'XXXX%'
or
SELECT FROM table_name
WHERE column LIKE '%XXXX%'
or
SELECT FROM table_name
WHERE column LIKE 'XXXX_'
or
SELECT FROM table_name
WHERE column LIKE '_XXXX'
or
SELECT FROM table_name
WHERE column LIKE '_XXXX_'
Sie können kombinieren NAnzahl der Bedingungen mit UND- oder ODER-Operatoren. Hier kann XXXX ein beliebiger numerischer Wert oder ein Zeichenfolgenwert sein.
Beispiel
In der folgenden Tabelle sind einige Beispiele aufgeführt, die zeigen, wo der WHERE-Teil eine andere LIKE-Klausel mit den Operatoren '%' und '_' hat.
Sr.Nr. | Aussage & Beschreibung |
---|---|
1 | WHERE SALARY LIKE '200%' Findet alle Werte, die mit 200 beginnen |
2 | WHERE SALARY LIKE '%200%' Findet alle Werte mit 200 an einer beliebigen Position |
3 | WHERE SALARY LIKE '_00%' Findet alle Werte mit 00 an der zweiten und dritten Position |
4 | WHERE SALARY LIKE '2_%_%' Findet alle Werte, die mit 2 beginnen und mindestens 3 Zeichen lang sind |
5 | WHERE SALARY LIKE '%2' Findet alle Werte, die mit 2 enden |
6 | WHERE SALARY LIKE '_2%3' Findet alle Werte, die an zweiter Stelle eine 2 haben und mit einer 3 enden |
7 | WHERE SALARY LIKE '2___3' Findet alle Werte in einer fünfstelligen Zahl, die mit 2 beginnt und mit 3 endet |
Nehmen wir ein reales Beispiel, betrachten wir die COMPANY-Tabelle mit den folgenden Datensätzen.
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
1 Paul 32 California 20000.0
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
Im Folgenden finden Sie ein Beispiel, in dem alle Datensätze aus der COMPANY-Tabelle angezeigt werden, in der AGE mit 2 beginnt.
sqlite> SELECT * FROM COMPANY WHERE AGE LIKE '2%';
Dies führt zu folgendem Ergebnis.
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
2 Allen 25 Texas 15000.0
3 Teddy 23 Norway 20000.0
4 Mark 25 Rich-Mond 65000.0
5 David 27 Texas 85000.0
6 Kim 22 South-Hall 45000.0
7 James 24 Houston 10000.0
Im Folgenden finden Sie ein Beispiel, in dem alle Datensätze aus der Tabelle COMPANY angezeigt werden, in der ADDRESS einen Bindestrich (-) im Text enthält.
sqlite> SELECT * FROM COMPANY WHERE ADDRESS LIKE '%-%';
Dies führt zu folgendem Ergebnis.
ID NAME AGE ADDRESS SALARY
---------- ---------- ---------- ---------- ----------
4 Mark 25 Rich-Mond 65000.0
6 Kim 22 South-Hall 45000.0