persistence/DD.Persistence/Repositories/ITimestampedValuesRepository.cs

63 lines
2.9 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-10-31 15:01:12 +05:00
/// </summary>
public interface ITimestampedValuesRepository : ISyncRepository, ITimeSeriesBaseRepository
{
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>
Task<IEnumerable<Tuple<DateTimeOffset, object[]>>> 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>
Task<IEnumerable<Tuple<DateTimeOffset, object[]>>> GetFirst(Guid discriminatorId, int takeCount, CancellationToken token);
2025-01-17 17:21:54 +05:00
/// <summary>
/// Получение данных с конца
/// </summary>
/// <param name="discriminatorId">Дискриминатор (идентификатор) набора</param>
/// <param name="takeCount">Количество</param>
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<Tuple<DateTimeOffset, object[]>>> GetLast(Guid discriminatorId, int takeCount, CancellationToken token);
2024-10-31 15:01:12 +05:00
}