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 VariableTableRepository : BaseRepository, IVariableTableRepository { private readonly IMapper _mapper; /// /// 构造函数,注入 AutoMapper 和 SqlSugarDbContext。 /// /// AutoMapper 实例,用于实体模型和数据库模型之间的映射。 /// SqlSugar 数据库上下文,用于数据库操作。 /// 日志记录器实例。 public VariableTableRepository(IMapper mapper, SqlSugarDbContext dbContext, ILogger logger) : base(dbContext, logger) { _mapper = mapper; } /// /// 异步根据ID获取单个变量表。 /// /// 变量表的唯一标识符。 /// 对应的变量表实体,如果不存在则为null。 public async Task GetByIdAsync(int id) { var dbVariableTable = await base.GetByIdAsync(id); return _mapper.Map(dbVariableTable); } /// /// 异步获取所有变量表。 /// /// 包含所有变量表实体的列表。 public async Task> GetAllAsync() { var dbList = await base.GetAllAsync(); return _mapper.Map>(dbList); } /// /// 异步添加新变量表。 /// /// 要添加的变量表实体。 /// 添加成功后的变量表实体(包含数据库生成的ID等信息)。 public async Task AddAsync(VariableTable entity) { var dbVariableTable = await base.AddAsync(_mapper.Map(entity)); return _mapper.Map(dbVariableTable, entity); } /// /// 异步更新现有变量表。 /// /// 要更新的变量表实体。 /// 受影响的行数。 public async Task UpdateAsync(VariableTable entity) => await base.UpdateAsync(_mapper.Map(entity)); /// /// 异步删除变量表。 /// /// 要删除的变量表实体。 /// 受影响的行数。 public async Task DeleteAsync(VariableTable entity) => await base.DeleteAsync(_mapper.Map(entity)); /// /// 异步根据ID删除变量表。 /// /// 要删除变量表的唯一标识符。 /// 受影响的行数。 public async Task DeleteByIdAsync(int id) { var stopwatch = new Stopwatch(); stopwatch.Start(); var result = await Db.Deleteable(new DbVariableTable() { Id = id }) .ExecuteCommandAsync(); stopwatch.Stop(); _logger.LogInformation($"Delete {typeof(DbVariableTable)},ID={id},耗时:{stopwatch.ElapsedMilliseconds}ms"); return result; } /// /// 异步获取指定数量的变量表。 /// /// 要获取的变量表数量。 /// 包含指定数量变量表实体的列表。 public new async Task> TakeAsync(int number) { var dbList = await base.TakeAsync(number); return _mapper.Map>(dbList); } public async Task> AddBatchAsync(List entities) { var dbEntities = _mapper.Map>(entities); var addedEntities = await base.AddBatchAsync(dbEntities); return _mapper.Map>(addedEntities); } /// /// 异步根据设备ID删除所有关联的变量表。 /// /// 设备的唯一标识符。 /// 受影响的行数。 public async Task DeleteByDeviceIdAsync(int deviceId) { var stopwatch = new Stopwatch(); stopwatch.Start(); var result = await Db.Deleteable() .Where(it => it.DeviceId == deviceId) .ExecuteCommandAsync(); stopwatch.Stop(); _logger.LogInformation($"Delete VariableTable by DeviceId={deviceId}, 耗时:{stopwatch.ElapsedMilliseconds}ms"); return result; } }