1
0
mirror of https://github.com/spl0k/supysonic.git synced 2024-12-22 17:06:17 +00:00

Fixed last SQLite migration

Closes #151
This commit is contained in:
spl0k 2019-06-08 12:41:38 +02:00
parent e5716b417a
commit 70f18b981a

View File

@ -1,12 +1,14 @@
COMMIT;
PRAGMA foreign_keys = OFF;
BEGIN TRANSACTION;
DROP INDEX index_track_album_id_fk; DROP INDEX index_track_album_id_fk;
DROP INDEX index_track_artist_id_fk; DROP INDEX index_track_artist_id_fk;
DROP INDEX index_track_folder_id_fk; DROP INDEX index_track_folder_id_fk;
DROP INDEX index_track_root_folder_id_fk; DROP INDEX index_track_root_folder_id_fk;
DROP INDEX index_track_path; DROP INDEX index_track_path;
ALTER TABLE track RENAME TO track_old; CREATE TABLE track_new (
CREATE TABLE IF NOT EXISTS track (
id CHAR(36) PRIMARY KEY, id CHAR(36) PRIMARY KEY,
disc INTEGER NOT NULL, disc INTEGER NOT NULL,
number INTEGER NOT NULL, number INTEGER NOT NULL,
@ -27,17 +29,20 @@ CREATE TABLE IF NOT EXISTS track (
root_folder_id CHAR(36) NOT NULL REFERENCES folder, root_folder_id CHAR(36) NOT NULL REFERENCES folder,
folder_id CHAR(36) NOT NULL REFERENCES folder folder_id CHAR(36) NOT NULL REFERENCES folder
); );
CREATE INDEX IF NOT EXISTS index_track_album_id_fk ON track(album_id); CREATE INDEX IF NOT EXISTS index_track_album_id_fk ON track_new(album_id);
CREATE INDEX IF NOT EXISTS index_track_artist_id_fk ON track(artist_id); CREATE INDEX IF NOT EXISTS index_track_artist_id_fk ON track_new(artist_id);
CREATE INDEX IF NOT EXISTS index_track_folder_id_fk ON track(folder_id); CREATE INDEX IF NOT EXISTS index_track_folder_id_fk ON track_new(folder_id);
CREATE INDEX IF NOT EXISTS index_track_root_folder_id_fk ON track(root_folder_id); CREATE INDEX IF NOT EXISTS index_track_root_folder_id_fk ON track_new(root_folder_id);
CREATE UNIQUE INDEX IF NOT EXISTS index_track_path ON track(path_hash); CREATE UNIQUE INDEX IF NOT EXISTS index_track_path ON track_new(path_hash);
INSERT INTO track(id, disc, number, title, year, genre, duration, has_art, album_id, artist_id, bitrate, path, path_hash, created, last_modification, play_count, last_play, root_folder_id, folder_id) INSERT INTO track_new(id, disc, number, title, year, genre, duration, has_art, album_id, artist_id, bitrate, path, path_hash, created, last_modification, play_count, last_play, root_folder_id, folder_id)
SELECT id, disc, number, title, year, genre, duration, has_art, album_id, artist_id, bitrate, path, path_hash, created, last_modification, play_count, last_play, root_folder_id, folder_id SELECT id, disc, number, title, year, genre, duration, has_art, album_id, artist_id, bitrate, path, path_hash, created, last_modification, play_count, last_play, root_folder_id, folder_id
FROM track_old; FROM track;
DROP TABLE track_old; DROP TABLE track;
ALTER TABLE track_new RENAME TO track;
COMMIT; COMMIT;
VACUUM; VACUUM;
PRAGMA foreign_keys = ON;
BEGIN TRANSACTION;