SQLite - ATTACH-Datenbank
Stellen Sie sich einen Fall vor, in dem mehrere Datenbanken verfügbar sind und Sie jeweils eine davon verwenden möchten. SQLiteATTACH DATABASE Die Anweisung wird verwendet, um eine bestimmte Datenbank auszuwählen. Nach diesem Befehl werden alle SQLite-Anweisungen unter der angehängten Datenbank ausgeführt.
Syntax
Im Folgenden finden Sie die grundlegende Syntax der SQLite ATTACH DATABASE-Anweisung.
ATTACH DATABASE 'DatabaseName' As 'Alias-Name';
Mit dem obigen Befehl wird auch eine Datenbank erstellt, falls die Datenbank bereits nicht erstellt wurde. Andernfalls wird nur der Name der Datenbankdatei mit der logischen Datenbank 'Alias-Name' verknüpft.
Beispiel
Wenn Sie eine vorhandene Datenbank anhängen möchten testDB.db, dann wäre die ATTACH DATABASE-Anweisung wie folgt:
sqlite> ATTACH DATABASE 'testDB.db' as 'TEST';
Verwenden Sie SQLite .database Befehl zum Anzeigen der angehängten Datenbank.
sqlite> .database
seq name file
--- --------------- ----------------------
0 main /home/sqlite/testDB.db
2 test /home/sqlite/testDB.db
Die Datenbanknamen main und tempsind für die Primärdatenbank und die Datenbank reserviert, um temporäre Tabellen und andere temporäre Datenobjekte zu speichern. Diese beiden Datenbanknamen sind für jede Datenbankverbindung vorhanden und sollten nicht für Anhänge verwendet werden. Andernfalls wird die folgende Warnmeldung angezeigt.
sqlite> ATTACH DATABASE 'testDB.db' as 'TEMP';
Error: database TEMP is already in use
sqlite> ATTACH DATABASE 'testDB.db' as 'main';
Error: database TEMP is already in use