SQLite: Überprüfen ob Tabelle existiert
Info von Stefan Trost | Letztes Update am 22.02.2023 | Erstellt am 01.06.2014
Manchmal möchte man zunächst überprüfen, ob eine bestimmte Tabelle überhaupt existiert, bevor man eine SQL-Anweisung durchführt. Nötig kann dies zum Beispiel sein, bevor man eine Tabelle neu anlegt und sicher sein möchte, dass es eine Tabelle mit diesem Namen noch nicht gibt. Oder wir möchten Daten in eine Tabelle schreiben oder aus einer Tabelle lesen und wissen zu diesem Zeitpunkt noch nicht, ob die betreffende Tabelle bereits existiert. Auch in dieser Situation kann eine Prüfung sinnvoll sein um eine Fehlermeldung zu vermeiden und die Tabelle notfalls neu anlegen zu können.
In diesem Tutorial möchten wir uns ansehen, welche Möglichkeiten uns in diesem Zusammenhang mit SQLite zur Verfügung stehen. Wichtig ist dafür zunächst die von SQLite selbst verwaltete Tabelle "sqlite_master". In dieser Tabelle stehen die Namen aller vorhandenen Tabellen und können darüber auch abgefragt werden.
Hier ist ein Beispiel, wie wir das Vorhandensein der Tabelle "tab" überprüfen können:
SELECT name FROM sqlite_master WHERE type = 'table' AND name = 'tab';
Ist das Ergebnis dieser Abfrage leer, wissen wir, dass die Tabelle nicht existiert.
Temporäre Tabellen
Wichtig: Temporäre Tabellen stehen nicht in "sqlite_master", sie befinden sich in "sqlite_temp_master". Sind wir an einer temporären Tabelle interessiert, können wir in der Abfrage oben einfach "sqlite_master" durch "sqlite_temp_master" austauschen.
SELECT name FROM sqlite_temp_master WHERE type = 'table' AND name = 'tab_temp';
Hier testen wir auf die Existenz einer temporären Tabelle namens "tab_temp".
Tabelle nur erstellen, wenn sie noch nicht existiert
Für einige Szenarien existieren einfachere Lösungen. Stellen wir uns zum Beispiel vor, dass ein Programm einige Tabellen in einer Datenbank benötigt. Zum Zeitpunkt des Programmstarts ist unklar, ob das Programm schon einmal gestartet wurde und ob die betreffenden Tabellen bereits angelegt sind. Daher möchten wir überprüfen, ob eine bestimmte Tabelle schon existiert und die Tabelle nur dann anlegen, falls nicht.
CREATE TABLE IF NOT EXISTS 'tab' (...);
Für diesen Fall würde sich eher das Statement "CREATE TABLE IF NOT EXISTS" anbieten. Dieses Statement entspricht dem "CREATE TABLE"-Statement, ist aber ergänzt durch "IF NOT EXISTS". Das bedeutet, dass die neue Tabelle nur dann angelegt wird, wenn sie noch nicht existiert. Damit erspart man sich den Umweg, dies zunächst in einer eigenen Query prüfen zu müssen.
Über den Autor
Software von Stefan Trost finden Sie auf sttmedia.de. Benötigen Sie eine individuelle Software nach Ihren eigenen Wünschen? Schreiben Sie uns: sttmedia.de/kontakt
Profil anzeigen
Ähnliche Themen
MySQL: Zeilenumbrüche in MySQL
Tipp | 0 Kommentare
SQLite: Index über eine oder mehrere Spalten anlegen
Info | 0 Kommentare
MySQL: Daten aus Tabelle löschen - Unterschied zwischen TRUNCATE, DELETE und DROP
Tutorial | 0 Kommentare
MySQL: 3 Wege um Definitionen und Aufbau einer Tabelle anzuzeigen
Info | 0 Kommentare
PHP: Nur bestimmte Buchstaben, Zahlen und Zeichen in einem String zulassen
Tipp | 10 Kommentare
SQLite: String und Spalten verknüpfen mit SQLite (CONCAT)
Info | 2 Kommentare
SQLite: RPAD und LPAD in SQLite - Zeichen rechts und links auffüllen
Info | 1 Kommentar
Wichtiger Hinweis
Bitte beachten Sie: Die Beiträge auf askingbox.de sind Beiträge von Nutzern und sollen keine professionelle Beratung ersetzen. Sie werden nicht von Unabhängigen geprüft und spiegeln nicht zwingend die Meinung von askingbox.de wieder. Mehr erfahren.
Jetzt mitmachen
Stellen Sie Ihre eigene Frage oder schreiben Sie Ihren eigenen Artikel auf askingbox.de. So gehts.