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