using System.Diagnostics; using DMS.Core.Interfaces; using DMS.Core.Interfaces.Repositories; using DMS.Core.Models; using DMS.Infrastructure.Data; using DMS.Infrastructure.Entities; /// /// 用户仓储类,用于操作DbUser实体 /// using AutoMapper; using DMS.Core.Helper; using DMS.Core.Interfaces; using DMS.Core.Interfaces.Repositories; using DMS.Core.Models; using DMS.Infrastructure.Data; using DMS.Infrastructure.Entities; namespace DMS.Infrastructure.Repositories; /// /// 用户仓储类,用于操作DbUser实体 /// public class UserRepository : BaseRepository, IUserRepository { private readonly IMapper _mapper; public UserRepository(IMapper mapper, SqlSugarDbContext dbContext) : base(dbContext) { _mapper = mapper; } public async Task GetByIdAsync(int id) { var dbUser = await base.GetByIdAsync(id); return _mapper.Map(dbUser); } public async Task> GetAllAsync() { var dbList = await base.GetAllAsync(); return _mapper.Map>(dbList); } public async Task AddAsync(User entity) { var dbUser = await base.AddAsync(_mapper.Map(entity)); return _mapper.Map(dbUser, entity); } public async Task UpdateAsync(User entity) => await base.UpdateAsync(_mapper.Map(entity)); public async Task DeleteAsync(User entity) => await base.DeleteAsync(_mapper.Map(entity)); public async Task DeleteAsync(int id) { var stopwatch = new Stopwatch(); stopwatch.Start(); var result = await Db.Deleteable(new User() { Id = id }) .ExecuteCommandAsync(); stopwatch.Stop(); NlogHelper.Info($"Delete {typeof(DbMenu)},ID={id},耗时:{stopwatch.ElapsedMilliseconds}ms"); return result; } }