Lidarr/NzbDrone.Core/SeriesStats/SeriesStatisticsRepository.cs

40 lines
1.4 KiB
C#
Raw Normal View History

2013-04-20 23:36:23 +00:00
using System;
using System.Collections.Generic;
using NzbDrone.Core.Datastore;
namespace NzbDrone.Core.SeriesStats
{
public interface ISeriesStatisticsRepository
{
List<SeriesStatistics> SeriesStatistics();
}
public class SeriesStatisticsRepository : ISeriesStatisticsRepository
{
private readonly IDatabase _database;
2013-04-20 23:36:23 +00:00
public SeriesStatisticsRepository(IDatabase database)
{
_database = database;
2013-04-20 23:36:23 +00:00
}
public List<SeriesStatistics> SeriesStatistics()
{
var mapper = _database.GetDataMapper();
2013-04-20 23:36:23 +00:00
mapper.AddParameter("currentDate", DateTime.UtcNow);
const string queryText = @"SELECT
2013-04-20 23:36:23 +00:00
SeriesId,
SUM(CASE WHEN Monitored = 1 AND Airdate <= @currentDate THEN 1 ELSE 0 END) AS EpisodeCount,
SUM(CASE WHEN Monitored = 1 AND Episodes.EpisodeFileId > 0 AND AirDate <= @currentDate THEN 1 ELSE 0 END) as EpisodeFileCount,
2013-04-22 01:21:24 +00:00
MAX(Episodes.SeasonNumber) as SeasonCount,
2013-04-20 23:36:23 +00:00
MIN(CASE WHEN AirDate < @currentDate THEN NULL ELSE AirDate END) as NextAiringString
FROM Episodes
GROUP BY SeriesId";
return mapper.Query<SeriesStatistics>(queryText);
2013-04-20 23:36:23 +00:00
}
}
}