using System.Diagnostics; using DMS.Core.Interfaces.Repositories; using DMS.Core.Models; using DMS.Infrastructure.Data; using DMS.Infrastructure.Entities; using AutoMapper; using Microsoft.Extensions.Logging; namespace DMS.Infrastructure.Repositories; /// /// 变量历史仓储实现类,负责变量历史数据的持久化操作。 /// 继承自 并实现 接口。 /// public class VariableHistoryRepository : BaseRepository, IVariableHistoryRepository { private readonly IMapper _mapper; /// /// 构造函数,注入 AutoMapper 和 SqlSugarDbContext。 /// /// AutoMapper 实例,用于实体模型和数据库模型之间的映射。 /// SqlSugar 数据库上下文,用于数据库操作。 /// 日志记录器实例。 public VariableHistoryRepository(IMapper mapper, SqlSugarDbContext dbContext, ILogger logger) : base(dbContext, logger) { _mapper = mapper; } /// /// 异步根据ID获取单个变量历史记录。 /// /// 变量历史记录的唯一标识符。 /// 对应的变量历史实体,如果不存在则为null。 public async Task GetByIdAsync(int id) { var dbVariableHistory = await base.GetByIdAsync(id); return _mapper.Map(dbVariableHistory); } /// /// 异步获取所有变量历史记录。 /// /// 包含所有变量历史实体的列表。 public async Task> GetAllAsync() { var dbList = await base.GetAllAsync(); return _mapper.Map>(dbList); } /// /// 异步添加新变量历史记录。 /// /// 要添加的变量历史实体。 /// 添加成功后的变量历史实体(包含数据库生成的ID等信息)。 public async Task AddAsync(VariableHistory entity) { var dbVariableHistory = await base.AddAsync(_mapper.Map(entity)); return _mapper.Map(dbVariableHistory, entity); } /// /// 异步更新现有变量历史记录。 /// /// 要更新的变量历史实体。 /// 受影响的行数。 public async Task UpdateAsync(VariableHistory entity) => await base.UpdateAsync(_mapper.Map(entity)); /// /// 异步删除变量历史记录。 /// /// 要删除的变量历史实体。 /// 受影响的行数。 public async Task DeleteAsync(VariableHistory entity) => await base.DeleteAsync(new List { _mapper.Map(entity) }); public async Task> AddAsync(List entities) { var dbEntities = _mapper.Map>(entities); var addedEntities = await base.AddAsync(dbEntities); return _mapper.Map>(addedEntities); } /// /// 根据变量ID获取历史记录 /// /// 变量ID /// 变量历史记录列表 public async Task> GetByVariableIdAsync(int variableId) { var dbList = await _dbContext.GetInstance().Queryable() .Where(h => h.VariableId == variableId) .OrderBy(h => h.Timestamp, SqlSugar.OrderByType.Desc) .ToListAsync(); return _mapper.Map>(dbList); } /// /// 根据变量ID获取历史记录,支持条数限制和时间范围筛选 /// /// 变量ID /// 返回记录的最大数量,null表示无限制 /// 开始时间,null表示无限制 /// 结束时间,null表示无限制 /// 变量历史记录列表 public async Task> GetByVariableIdAsync(int variableId, int? limit = null, DateTime? startTime = null, DateTime? endTime = null) { var query = _dbContext.GetInstance().Queryable() .Where(h => h.VariableId == variableId); // 添加时间范围筛选 if (startTime.HasValue) query = query.Where(h => h.Timestamp >= startTime.Value); if (endTime.HasValue) query = query.Where(h => h.Timestamp <= endTime.Value); // 按时间倒序排列 query = query.OrderBy(h => h.Timestamp, SqlSugar.OrderByType.Desc); // 添加条数限制 if (limit.HasValue) query = query.Take(limit.Value); var dbList = await query.ToListAsync(); return _mapper.Map>(dbList); } /// /// 获取所有历史记录,支持条数限制和时间范围筛选 /// /// 返回记录的最大数量,null表示无限制 /// 开始时间,null表示无限制 /// 结束时间,null表示无限制 /// 所有历史记录列表 public new async Task> GetAllAsync(int? limit = null, DateTime? startTime = null, DateTime? endTime = null) { var query = _dbContext.GetInstance().Queryable(); // 添加时间范围筛选 if (startTime.HasValue) query = query.Where(h => h.Timestamp >= startTime.Value); if (endTime.HasValue) query = query.Where(h => h.Timestamp <= endTime.Value); // 按时间倒序排列 query = query.OrderBy(h => h.Timestamp, SqlSugar.OrderByType.Desc); // 添加条数限制 if (limit.HasValue) query = query.Take(limit.Value); var dbList = await query.ToListAsync(); return _mapper.Map>(dbList); } /// /// 异步根据实体列表批量删除变量历史记录。 /// /// 要删除的变量历史实体列表。 /// 受影响的行数。 public async Task DeleteAsync(List entities) { var dbEntities = _mapper.Map>(entities); return await base.DeleteAsync(dbEntities); } }