X-Git-Url: https://git.sesse.net/?p=pr0n;a=blobdiff_plain;f=sql%2Fupgrade-v2.50.sql;h=1baba2cc1885ad55bb7d5cb15fdb7bee64de6dbd;hp=0d44ba3cd700b4135cb0cb9fcd5c1c5af8505d42;hb=6eef2c55c264bcb6f3a7fcc05ff9ae2b816314cb;hpb=82b2e541984df6f697a5a73f2faaa99e40dfc832 diff --git a/sql/upgrade-v2.50.sql b/sql/upgrade-v2.50.sql index 0d44ba3..1baba2c 100644 --- a/sql/upgrade-v2.50.sql +++ b/sql/upgrade-v2.50.sql @@ -1,5 +1,5 @@ -- --- Upgrades pre-v2.50 databases to 2.50 format -- not many changes, though. +-- Upgrades pre-v2.50 databases to 2.50 format. -- SET work_mem=131072; @@ -24,3 +24,42 @@ ALTER TABLE images ALTER COLUMN width SET DEFAULT NULL; ALTER TABLE images ALTER COLUMN height SET DEFAULT NULL; UPDATE images SET width=NULL,height=NULL WHERE width=-1 OR height=-1; ALTER TABLE images ADD CONSTRAINT width_height_nullity CHECK ((width IS NULL) = (height IS NULL)); + +ALTER TABLE deleted_images ALTER COLUMN width DROP NOT NULL; +ALTER TABLE deleted_images ALTER COLUMN height DROP NOT NULL; +ALTER TABLE deleted_images ALTER COLUMN width SET DEFAULT NULL; +ALTER TABLE deleted_images ALTER COLUMN height SET DEFAULT NULL; +UPDATE deleted_images SET width=NULL,height=NULL WHERE width=-1 OR height=-1; +ALTER TABLE deleted_images ADD CONSTRAINT width_height_nullity CHECK ((width IS NULL) = (height IS NULL)); + +-- model/lens denormalization (reduce usage of exif_info) +ALTER TABLE images ADD COLUMN model varchar; +ALTER TABLE images ADD COLUMN lens varchar; +UPDATE images SET lens=COALESCE( + TRIM(( + SELECT value FROM exif_info WHERE key='Lens' AND images.id=exif_info.image + )), + TRIM(( + SELECT value FROM exif_info WHERE key='LensSpec' AND images.id=exif_info.image + )) +), model=TRIM(( + SELECT value FROM exif_info WHERE key='Model' AND images.id=exif_info.image +)); +UPDATE images SET model=NULL WHERE model=''; +UPDATE images SET lens=NULL WHERE lens=''; + +ALTER TABLE deleted_images ADD COLUMN model varchar; +ALTER TABLE deleted_images ADD COLUMN lens varchar; +UPDATE deleted_images SET lens=COALESCE( + TRIM(( + SELECT value FROM exif_info WHERE key='Lens' AND deleted_images.id=exif_info.image + )), + TRIM(( + SELECT value FROM exif_info WHERE key='LensSpec' AND deleted_images.id=exif_info.image + )) +), model=TRIM(( + SELECT value FROM exif_info WHERE key='Model' AND deleted_images.id=exif_info.image +)); +UPDATE deleted_images SET model=NULL WHERE model=''; +UPDATE deleted_images SET lens=NULL WHERE lens=''; +