persistence/DD.Persistence/Repositories/ITimestampedValuesRepository.cs

58 lines
2.8 KiB
C#
Raw Normal View History

using DD.Persistence.Models;
using DD.Persistence.RepositoriesAbstractions;
namespace DD.Persistence.Repositories;
2024-10-31 15:01:12 +05:00
/// <summary>
2024-11-02 12:05:12 +05:00
/// Интерфейс по работе с временными данными
2024-10-31 15:01:12 +05:00
/// </summary>
public interface ITimestampedValuesRepository : ISyncRepository, ITimeSeriesBaseRepository
2024-10-31 15:01:12 +05:00
{
2024-11-01 12:26:14 +05:00
/// <summary>
/// Добавление записей
/// </summary>
/// <param name="idDiscriminator"></param>
2024-11-01 12:26:14 +05:00
/// <param name="dtos"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> AddRange(Guid idDiscriminator, IEnumerable<TimestampedValuesDto> dtos, CancellationToken token);
/// <summary>
2025-01-17 17:21:54 +05:00
/// Количество записей по указанному набору в БД. Для пагинации
/// </summary>
/// <param name="idDiscriminator">Дискриминатор (идентификатор) набора</param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> Count(Guid idDiscriminator, CancellationToken token);
/// <summary>
2025-01-17 17:21:54 +05:00
/// Получение данных с фильтрацией. Значение фильтра null - отключен
/// </summary>
/// <param name="idDiscriminator">Дискриминатор (идентификатор) набора</param>
2025-01-17 17:21:54 +05:00
/// <param name="geTimestamp">Фильтр позднее даты</param>
/// <param name="columnNames">Фильтр свойств набора. Можно запросить только некоторые свойства из набора</param>
2025-01-17 17:21:54 +05:00
/// <param name="skip"></param>
/// <param name="take"></param>
/// <param name="token"></param>
/// <returns></returns>
2025-01-17 17:21:54 +05:00
Task<IEnumerable<TimestampedValuesDto>> Get(Guid idDiscriminator, DateTimeOffset? geTimestamp, IEnumerable<string>? columnNames, int skip, int take, CancellationToken token);
/// <summary>
2025-01-17 17:21:54 +05:00
/// Получение данных с начала
/// </summary>
2025-01-17 17:21:54 +05:00
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
/// <param name="takeCount">Количество</param>
/// <param name="token"></param>
/// <returns></returns>
2025-01-17 17:21:54 +05:00
Task<IEnumerable<TimestampedValuesDto>> GetFirst(Guid discriminatorId, int takeCount, CancellationToken token);
/// <summary>
/// Получение данных с конца
/// </summary>
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
/// <param name="takeCount">Количество</param>
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<TimestampedValuesDto>> GetLast(Guid discriminatorId, int takeCount, CancellationToken token);
2024-10-31 15:01:12 +05:00
}