From 1294a86a416b2a1532ea107361a99e39538c479c Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 17 Dec 2025 22:31:04 -0500 Subject: [PATCH] Add indexes for improved query performance --- .../2025-12-17-230000_add_indexes/down.sql | 9 +++++++++ migrations/2025-12-17-230000_add_indexes/up.sql | 17 +++++++++++++++++ 2 files changed, 26 insertions(+) create mode 100644 migrations/2025-12-17-230000_add_indexes/down.sql create mode 100644 migrations/2025-12-17-230000_add_indexes/up.sql diff --git a/migrations/2025-12-17-230000_add_indexes/down.sql b/migrations/2025-12-17-230000_add_indexes/down.sql new file mode 100644 index 0000000..3025574 --- /dev/null +++ b/migrations/2025-12-17-230000_add_indexes/down.sql @@ -0,0 +1,9 @@ +-- Rollback indexes + +DROP INDEX IF EXISTS idx_favorites_userid; +DROP INDEX IF EXISTS idx_favorites_path; +DROP INDEX IF EXISTS idx_tags_name; +DROP INDEX IF EXISTS idx_tagged_photo_photo_name; +DROP INDEX IF EXISTS idx_tagged_photo_tag_id; +DROP INDEX IF EXISTS idx_image_exif_camera; +DROP INDEX IF EXISTS idx_image_exif_gps; diff --git a/migrations/2025-12-17-230000_add_indexes/up.sql b/migrations/2025-12-17-230000_add_indexes/up.sql new file mode 100644 index 0000000..276c70b --- /dev/null +++ b/migrations/2025-12-17-230000_add_indexes/up.sql @@ -0,0 +1,17 @@ +-- Add indexes for improved query performance + +-- Favorites table indexes +CREATE INDEX IF NOT EXISTS idx_favorites_userid ON favorites(userid); +CREATE INDEX IF NOT EXISTS idx_favorites_path ON favorites(path); + +-- Tags table indexes +CREATE INDEX IF NOT EXISTS idx_tags_name ON tags(name); + +-- Tagged photos indexes +CREATE INDEX IF NOT EXISTS idx_tagged_photo_photo_name ON tagged_photo(photo_name); +CREATE INDEX IF NOT EXISTS idx_tagged_photo_tag_id ON tagged_photo(tag_id); + +-- EXIF table indexes (date_taken already has index from previous migration) +-- Adding composite index for common EXIF queries +CREATE INDEX IF NOT EXISTS idx_image_exif_camera ON image_exif(camera_make, camera_model); +CREATE INDEX IF NOT EXISTS idx_image_exif_gps ON image_exif(gps_latitude, gps_longitude);