pytasz o składnię ALTER COLUMN, ale nie mówisz, co chcesz zrobić. To sprawia, że myślę, że jest to zbyt szerokie. ALTER COLUMN może wiele zdziałać, czy chcesz porzucić ograniczenie niezerowe, jak w przykładzie pg?
Evan Carroll,
jeśli używane narzędzia intellj db, po zmianie kolumny wygenerują polecenia dla twojego sqlite.
Chociaż prawdą jest, że nie ma ALTER COLUMN, jeśli chcesz tylko zmienić nazwę kolumny, usunąć ograniczenie NOT NULL lub zmienić typ danych, możesz użyć następującego zestawu niebezpiecznych poleceń:
PRAGMA writable_schema = 1;
UPDATE SQLITE_MASTER SETSQL = 'CREATE TABLE BOOKS ( title TEXT NOT NULL, publication_date TEXT)'WHERENAME = 'BOOKS';
PRAGMA writable_schema = 0;
Będziesz musiał zamknąć i ponownie otworzyć połączenie lub odkurzyć bazę danych, aby ponownie załadować zmiany w schemacie.
Na przykład:
Y:\> **sqlite3 booktest**
SQLite version 3.7.4
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> **createtable BOOKS ( title TEXTNOTNULL, publication_date TEXTNOTNULL);**
sqlite> **insertinto BOOKS VALUES ("NULLTEST",null);**
Error: BOOKS.publication_date may not be NULL
sqlite> **PRAGMA writable_schema = 1;**
sqlite> **UPDATE SQLITE_MASTER SETSQL = 'CREATE TABLE BOOKS ( title TEXT NOT
NULL, publication_date TEXT)'WHERENAME = 'BOOKS';**
sqlite> **PRAGMA writable_schema = 0;**
sqlite> **.q**
Y:\> **sqlite3 booktest**
SQLite version 3.7.4
Enter ".help" for instructions
Enter SQL statements terminated with a ";"
sqlite> **insertinto BOOKS VALUES ("NULLTEST",null);**
sqlite> **.q**
ODNIESIENIA NASTĘPUJĄCE:
pragma writable_schema
Gdy ta pragma jest włączona, tabele SQLITE_MASTER, w których można zmienić bazę danych za pomocą zwykłych instrukcji UPDATE, INSERT i DELETE. Ostrzeżenie: niewłaściwe użycie tej pragmy może łatwo spowodować uszkodzenie pliku bazy danych.
[alter table] (z http://www.sqlite.org/lang_altertable.html )
SQLite obsługuje ograniczony podzbiór ALTER TABLE. Polecenie ALTER TABLE w SQLite umożliwia użytkownikowi zmianę nazwy tabeli lub dodanie nowej kolumny do istniejącej tabeli. Nie można zmienić nazwy kolumny, usunąć kolumny ani dodać lub usunąć ograniczeń z tabeli.
Ta metoda zadziałała dla mnie, chociaż aby uniknąć sytuacji, w których kolumny mogą być w innej kolejności (tj. Z poprzedniego polecenia ADD COLUMN), użyłem: UPDATE SQLITE_MASTER SET SQL = replace (SQL, '[MyColumn] integer NOT NULL' ' , „[MyColumn] integer NULL”) WHERE NAME = „MyTable”. Uważaj również, aby nie uruchamiać tego jako części transakcji - może to uniemożliwić uruchomienie niektórych wcześniejszych poleceń transakcji.
Ross
32
SQLite obsługuje ograniczony podzbiór ALTER TABLE. Polecenie ALTER TABLE w SQLite umożliwia użytkownikowi zmianę nazwy tabeli lub dodanie nowej kolumny do istniejącej tabeli. Nie można zmienić nazwy kolumny, usunąć kolumny ani dodać lub usunąć ograniczeń z tabeli. Możesz jednak zmienić typ danych kolumny tabeli lub inną właściwość, wykonując następujące kroki.
BEGIN TRANSACTION;
UTWÓRZ TABELĘ TYMCZASOWĄ t1_backup (a, b);
INSERT INTO t1_backup SELECT a, b FROM t1;
DROP TABLE t1;
TWORZENIE TABELI t1 (a, b);
INSERT INTO t1 SELECT a, b FROM t1_backup;
DROP TABLE t1_backup;
POPEŁNIĆ
Aby uzyskać więcej informacji, możesz odnieść się do linku .
Odpowiedzi:
W sqlite nie ma ALTER COLUMN.
Uważam, że jedyną opcją jest:
Ta inna odpowiedź Stackoverflow wyjaśnia szczegółowo ten proces
źródło
Chociaż prawdą jest, że nie ma ALTER COLUMN, jeśli chcesz tylko zmienić nazwę kolumny, usunąć ograniczenie NOT NULL lub zmienić typ danych, możesz użyć następującego zestawu niebezpiecznych poleceń:
PRAGMA writable_schema = 1; UPDATE SQLITE_MASTER SET SQL = 'CREATE TABLE BOOKS ( title TEXT NOT NULL, publication_date TEXT)' WHERE NAME = 'BOOKS'; PRAGMA writable_schema = 0;
Będziesz musiał zamknąć i ponownie otworzyć połączenie lub odkurzyć bazę danych, aby ponownie załadować zmiany w schemacie.
Na przykład:
Y:\> **sqlite3 booktest** SQLite version 3.7.4 Enter ".help" for instructions Enter SQL statements terminated with a ";" sqlite> **create table BOOKS ( title TEXT NOT NULL, publication_date TEXT NOT NULL);** sqlite> **insert into BOOKS VALUES ("NULLTEST",null);** Error: BOOKS.publication_date may not be NULL sqlite> **PRAGMA writable_schema = 1;** sqlite> **UPDATE SQLITE_MASTER SET SQL = 'CREATE TABLE BOOKS ( title TEXT NOT NULL, publication_date TEXT)' WHERE NAME = 'BOOKS';** sqlite> **PRAGMA writable_schema = 0;** sqlite> **.q** Y:\> **sqlite3 booktest** SQLite version 3.7.4 Enter ".help" for instructions Enter SQL statements terminated with a ";" sqlite> **insert into BOOKS VALUES ("NULLTEST",null);** sqlite> **.q**
ODNIESIENIA NASTĘPUJĄCE:
pragma writable_schema
Gdy ta pragma jest włączona, tabele SQLITE_MASTER, w których można zmienić bazę danych za pomocą zwykłych instrukcji UPDATE, INSERT i DELETE. Ostrzeżenie: niewłaściwe użycie tej pragmy może łatwo spowodować uszkodzenie pliku bazy danych.
[alter table] (z http://www.sqlite.org/lang_altertable.html )
SQLite obsługuje ograniczony podzbiór ALTER TABLE. Polecenie ALTER TABLE w SQLite umożliwia użytkownikowi zmianę nazwy tabeli lub dodanie nowej kolumny do istniejącej tabeli. Nie można zmienić nazwy kolumny, usunąć kolumny ani dodać lub usunąć ograniczeń z tabeli.
źródło
SQLite obsługuje ograniczony podzbiór ALTER TABLE. Polecenie ALTER TABLE w SQLite umożliwia użytkownikowi zmianę nazwy tabeli lub dodanie nowej kolumny do istniejącej tabeli. Nie można zmienić nazwy kolumny, usunąć kolumny ani dodać lub usunąć ograniczeń z tabeli. Możesz jednak zmienić typ danych kolumny tabeli lub inną właściwość, wykonując następujące kroki.
Aby uzyskać więcej informacji, możesz odnieść się do linku .
źródło