SQLite - GLOB-Klausel

SQLite GLOBDer Operator wird verwendet, um nur Textwerte mithilfe von Platzhaltern mit einem Muster abzugleichen. Wenn der Suchausdruck mit dem Musterausdruck abgeglichen werden kann, gibt der GLOB-Operator true zurück (1). Im Gegensatz zum LIKE-Operator unterscheidet GLOB zwischen Groß- und Kleinschreibung und folgt der UNIX-Syntax zur Angabe der folgenden Platzhalter.

  • Das Sternchen (*)
  • Das Fragezeichen (?)

Das Sternchen (*) steht für null oder mehrere Zahlen oder Zeichen. Das Fragezeichen (?) Steht für eine einzelne Zahl oder ein einzelnes Zeichen.

Syntax

Es folgt die grundlegende Syntax von * und ?.

SELECT FROM table_name
WHERE column GLOB 'XXXX*'
or 
SELECT FROM table_name
WHERE column GLOB '*XXXX*'
or
SELECT FROM table_name
WHERE column GLOB 'XXXX?'
or
SELECT FROM table_name
WHERE column GLOB '?XXXX'
or
SELECT FROM table_name
WHERE column GLOB '?XXXX?'
or
SELECT FROM table_name
WHERE column GLOB '????'

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 '*' und '?' Betreiber.

Sr.Nr. Aussage & Beschreibung
1

WHERE SALARY GLOB '200*'

Findet alle Werte, die mit 200 beginnen

2

WHERE SALARY GLOB '*200*'

Findet alle Werte mit 200 an einer beliebigen Position

3

WHERE SALARY GLOB '?00*'

Findet alle Werte mit 00 an der zweiten und dritten Position

4

WHERE SALARY GLOB '2??'

Findet alle Werte, die mit 2 beginnen und mindestens 3 Zeichen lang sind

5

WHERE SALARY GLOB '*2'

Findet alle Werte, die mit 2 enden

6

WHERE SALARY GLOB '?2*3'

Findet alle Werte, die eine 2 an zweiter Stelle haben und mit einer 3 enden

7

WHERE SALARY GLOB '2???3'

Findet alle Werte in einer fünfstelligen Zahl, die mit 2 beginnen und mit 3 enden

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 Tabelle COMPANY angezeigt werden, wobei AGE mit 2 beginnt.

sqlite> SELECT * FROM COMPANY WHERE AGE  GLOB '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 COMPANY-Tabelle angezeigt werden, in der ADDRESS einen Bindestrich (-) im Text enthält.

sqlite> SELECT * FROM COMPANY WHERE ADDRESS  GLOB '*-*';

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