SQLite - Ansichten

Eine Ansicht ist nichts anderes als eine SQLite-Anweisung, die in der Datenbank mit einem zugeordneten Namen gespeichert ist. Es ist eigentlich eine Zusammensetzung einer Tabelle in Form einer vordefinierten SQLite-Abfrage.

Eine Ansicht kann alle Zeilen einer Tabelle oder ausgewählte Zeilen aus einer oder mehreren Tabellen enthalten. Eine Ansicht kann aus einer oder mehreren Tabellen erstellt werden. Dies hängt von der geschriebenen SQLite-Abfrage ab, um eine Ansicht zu erstellen.

Ansichten, bei denen es sich um virtuelle Tabellen handelt, ermöglichen den Benutzern Folgendes:

  • Strukturieren Sie Daten so, dass Benutzer oder Benutzerklassen sie natürlich oder intuitiv finden.

  • Beschränken Sie den Zugriff auf die Daten so, dass ein Benutzer nur begrenzte Daten anstelle einer vollständigen Tabelle sehen kann.

  • Fassen Sie Daten aus verschiedenen Tabellen zusammen, mit denen Berichte erstellt werden können.

SQLite-Ansichten sind schreibgeschützt und daher können Sie möglicherweise keine DELETE-, INSERT- oder UPDATE-Anweisung für eine Ansicht ausführen. Sie können jedoch einen Auslöser für eine Ansicht erstellen, die beim Versuch ausgelöst wird, eine Ansicht zu LÖSCHEN, EINFÜGEN oder AKTUALISIEREN, und im Hauptteil des Auslösers das zu tun, was Sie benötigen.

Ansichten erstellen

SQLite-Ansichten werden mit dem erstellt CREATE VIEWErklärung. SQLite-Ansichten können aus einer einzelnen Tabelle, mehreren Tabellen oder einer anderen Ansicht erstellt werden.

Im Folgenden finden Sie die grundlegende Syntax von CREATE VIEW.

CREATE [TEMP | TEMPORARY] VIEW view_name AS
SELECT column1, column2.....
FROM table_name
WHERE [condition];

Sie können mehrere Tabellen in Ihre SELECT-Anweisung aufnehmen, ähnlich wie Sie sie in einer normalen SQL SELECT-Abfrage verwenden. Wenn das optionale Schlüsselwort TEMP oder TEMPORARY vorhanden ist, wird die Ansicht in der temporären Datenbank erstellt.

Beispiel

Betrachten Sie 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 zum Erstellen einer Ansicht aus der COMPANY-Tabelle. In dieser Ansicht werden nur wenige Spalten aus der COMPANY-Tabelle angezeigt.

sqlite> CREATE VIEW COMPANY_VIEW AS
SELECT ID, NAME, AGE
FROM  COMPANY;

Sie können jetzt COMPANY_VIEW auf ähnliche Weise abfragen wie eine tatsächliche Tabelle. Das Folgende ist ein Beispiel -

sqlite> SELECT * FROM COMPANY_VIEW;

Dies führt zu folgendem Ergebnis.

ID          NAME        AGE
----------  ----------  ----------
1           Paul        32
2           Allen       25
3           Teddy       23
4           Mark        25
5           David       27
6           Kim         22
7           James       24

Ansichten löschen

Verwenden Sie zum Löschen einer Ansicht einfach die Anweisung DROP VIEW mit der view_name. Die grundlegende DROP VIEW-Syntax lautet wie folgt:

sqlite> DROP VIEW view_name;

Der folgende Befehl löscht die Ansicht COMPANY_VIEW, die wir im letzten Abschnitt erstellt haben.

sqlite> DROP VIEW COMPANY_VIEW;