SQLite - INDEXED BY-Klausel

Die Klausel "INDEXED BY Indexname" gibt an, dass der benannte Index verwendet werden muss, um die Werte in der vorhergehenden Tabelle nachzuschlagen.

Wenn der Indexname nicht vorhanden ist oder nicht für die Abfrage verwendet werden kann, schlägt die Vorbereitung der SQLite-Anweisung fehl.

Die Klausel "NOT INDEXED" gibt an, dass beim Zugriff auf die vorhergehende Tabelle kein Index verwendet werden soll, einschließlich impliziter Indizes, die durch Einschränkungen von UNIQUE und PRIMARY KEY erstellt wurden.

Der INTEGER PRIMARY KEY kann jedoch weiterhin zum Nachschlagen von Einträgen verwendet werden, selbst wenn "NOT INDEXED" angegeben ist.

Syntax

Es folgt die Syntax für die INDEXED BY-Klausel, die mit der Anweisung DELETE, UPDATE oder SELECT verwendet werden kann.

SELECT|DELETE|UPDATE column1, column2...
INDEXED BY (index_name)
table_name
WHERE (CONDITION);

Beispiel

Betrachten Sie die Tabelle COMPANY. Wir erstellen einen Index und verwenden ihn zur Durchführung der INDEXED BY-Operation.

sqlite> CREATE INDEX salary_index ON COMPANY(salary);
sqlite>

Wenn Sie nun die Daten aus der Tabelle COMPANY auswählen, können Sie die INDEXED BY-Klausel wie folgt verwenden:

sqlite> SELECT * FROM COMPANY INDEXED BY salary_index WHERE salary > 5000;

Dies führt zu folgendem Ergebnis.

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
7           James       24          Houston     10000.0
2           Allen       25          Texas       15000.0
1           Paul        32          California  20000.0
3           Teddy       23          Norway      20000.0
6           Kim         22          South-Hall  45000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0