removed secondary artists
This commit is contained in:
@@ -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(())
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -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),
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user