Compare commits

..

1 Commits

Author SHA1 Message Date
Connor Johnstone e76b2fc575 removed secondary artists 2026-03-23 17:11:38 -04:00
2 changed files with 27 additions and 0 deletions
@@ -0,0 +1,25 @@
use sea_orm_migration::prelude::*;
#[derive(DeriveMigrationName)]
pub struct Migration;
#[async_trait::async_trait]
impl MigrationTrait for Migration {
async fn up(&self, manager: &SchemaManager) -> Result<(), DbErr> {
let conn = manager.get_connection();
conn.execute_unprepared(
"DELETE FROM artists WHERE id NOT IN (
SELECT DISTINCT artist_id FROM tracks WHERE artist_id IS NOT NULL
UNION SELECT DISTINCT artist_id FROM wanted_items WHERE artist_id IS NOT NULL
UNION SELECT DISTINCT artist_id FROM albums WHERE artist_id IS NOT NULL
)",
)
.await?;
Ok(())
}
async fn down(&self, _manager: &SchemaManager) -> Result<(), DbErr> {
// Orphaned artists cannot be restored
Ok(())
}
}
+2
View File
@@ -14,6 +14,7 @@ mod m20260319_000012_add_user_id_to_wanted_items;
mod m20260320_000013_add_artist_monitoring; mod m20260320_000013_add_artist_monitoring;
mod m20260320_000014_create_playlists; mod m20260320_000014_create_playlists;
mod m20260320_000015_add_subsonic_password; mod m20260320_000015_add_subsonic_password;
mod m20260323_000016_remove_orphaned_artists;
pub struct Migrator; pub struct Migrator;
@@ -35,6 +36,7 @@ impl MigratorTrait for Migrator {
Box::new(m20260320_000013_add_artist_monitoring::Migration), Box::new(m20260320_000013_add_artist_monitoring::Migration),
Box::new(m20260320_000014_create_playlists::Migration), Box::new(m20260320_000014_create_playlists::Migration),
Box::new(m20260320_000015_add_subsonic_password::Migration), Box::new(m20260320_000015_add_subsonic_password::Migration),
Box::new(m20260323_000016_remove_orphaned_artists::Migration),
] ]
} }
} }