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