Files
Readarr/src/NzbDrone.Core/Housekeeping/Housekeepers/CleanupOrphanedTrackFiles.cs
T
ta264 c392569a63 New: Update DB to store all releases for an album (#517)
* New: Store all releases for an album and track artists

* Add Overview, links and release date by release

* Tidy up

* Fix metadata refresh errors following musicbrainz edits
2018-12-14 19:02:43 -05:00

46 lines
2.0 KiB
C#

using NzbDrone.Core.Datastore;
namespace NzbDrone.Core.Housekeeping.Housekeepers
{
public class CleanupOrphanedTrackFiles : IHousekeepingTask
{
private readonly IMainDatabase _database;
public CleanupOrphanedTrackFiles(IMainDatabase database)
{
_database = database;
}
public void Clean()
{
var mapper = _database.GetDataMapper();
// Delete where track no longer exists
mapper.ExecuteNonQuery(@"DELETE FROM TrackFiles
WHERE Id IN (
SELECT TrackFiles.Id FROM TrackFiles
LEFT OUTER JOIN Tracks
ON TrackFiles.Id = Tracks.TrackFileId
WHERE Tracks.Id IS NULL)");
// Delete trackfiles associated with releases that are not currently selected
mapper.ExecuteNonQuery(@"DELETE FROM TrackFiles
WHERE Id IN (
SELECT TrackFiles.Id FROM TrackFiles
JOIN Tracks ON TrackFiles.Id = Tracks.TrackFileId
JOIN AlbumReleases ON Tracks.AlbumReleaseId = AlbumReleases.Id
JOIN Albums ON AlbumReleases.AlbumId = Albums.Id
WHERE AlbumReleases.Monitored = 0)");
// Unlink Tracks where the Trackfiles entry no longer exists
mapper.ExecuteNonQuery(@"UPDATE Tracks
SET TrackFileId = 0
WHERE Id IN (
SELECT Tracks.Id FROM Tracks
LEFT OUTER JOIN TrackFiles
ON Tracks.TrackFileId = TrackFiles.Id
WHERE TrackFiles.Id IS NULL)");
}
}
}