TankReposity.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. using Edge.Core.Core.database;
  2. using Edge.Core.Domain.FccNozzleInfo.Output;
  3. using Edge.Core.Domain.FccTankInfo.Input;
  4. using Edge.Core.Domain.FccTankInfo.Output;
  5. using Microsoft.EntityFrameworkCore;
  6. namespace FccLite.Web.Repositories.FccTankInfo
  7. {
  8. public class TankReposity : ITankReposity
  9. {
  10. static NLog.Logger Logger = NLog.LogManager.GetCurrentClassLogger();
  11. private readonly MysqlDbContext _dbContext;
  12. public TankReposity(MysqlDbContext dbContext)
  13. {
  14. _dbContext = dbContext;
  15. }
  16. /// <summary>
  17. /// 增加油罐
  18. /// </summary>
  19. /// <param name="addTankInput">油罐信息</param>
  20. /// <returns></returns>
  21. public async Task<int> AddDetailsTankAsync(AddTankInput addTankInput)
  22. {
  23. _dbContext.TankInfos.Add(addTankInput.ToComponent());
  24. return await _dbContext.SaveChangesAsync();
  25. }
  26. /// <summary>
  27. /// 通过油罐id删除油罐
  28. /// </summary>
  29. /// <param name="id">油罐id</param>
  30. /// <returns></returns>
  31. public async Task<int> DeleteTankById(long id)
  32. {
  33. Edge.Core.Domain.FccTankInfo.FccTankInfo? tankInfo = await _dbContext.TankInfos.FirstOrDefaultAsync(info => info.Id == id);
  34. if (tankInfo == null)
  35. {
  36. Logger.Info($"find tank info with id :{id} for delete,result is null");
  37. return 0;
  38. }
  39. //先批量删除所关联的油枪
  40. List<Edge.Core.Domain.FccNozzleInfo.FccNozzleInfo> fccNozzleInfos = await _dbContext.NozzleInfos.Where(info => info.TankId == tankInfo.Id).ToListAsync();
  41. _dbContext.NozzleInfos.RemoveRange(fccNozzleInfos);
  42. //再删除油罐
  43. _dbContext.TankInfos.Remove(tankInfo);
  44. return await _dbContext.SaveChangesAsync();
  45. }
  46. /// <summary>
  47. /// 统计站点 id 获取油罐基本信息
  48. /// </summary>
  49. /// <param name="stationId">站点id</param>
  50. /// <returns></returns>
  51. public async Task<List<BaseTankInfoOutput>> GetBaseTankByStationIdAsync(long stationId)
  52. {
  53. var query = from tank in _dbContext.TankInfos
  54. join nozzle in _dbContext.NozzleInfos
  55. on tank.Id equals nozzle.TankId
  56. into baseTankInfo
  57. select new BaseTankInfoOutput()
  58. {
  59. Id = tank.Id,
  60. Number = tank.Number,
  61. OilId = tank.OilId,
  62. OilName = tank.OilName,
  63. AssociatedNozzles = baseTankInfo.Select(info => new BaseTankInfoOutput.AssociatedNozzle()
  64. {
  65. NozzleId = info.Id,
  66. NozzleNum = info.ExternalNum
  67. }).ToList()
  68. };
  69. return await query.ToListAsync();
  70. }
  71. /// <summary>
  72. /// 通过油罐id获取油罐详情信息
  73. /// </summary>
  74. /// <param name="tankId">油罐id</param>
  75. /// <returns></returns>
  76. public async Task<Edge.Core.Domain.FccTankInfo.FccTankInfo?> GetDetailsTankByTankIdAsync(long tankId)
  77. {
  78. return await _dbContext.TankInfos.FirstOrDefaultAsync(info => info.Id == tankId);
  79. }
  80. /// <summary>
  81. /// 修改油罐
  82. /// </summary>
  83. /// <param name="updateTankInput">油罐信息</param>
  84. /// <returns></returns>
  85. public async Task<int> UpdateDetailsTankAsync(UpdateTankInput updateTankInput)
  86. {
  87. Edge.Core.Domain.FccTankInfo.FccTankInfo? fccTankInfo = await _dbContext.TankInfos.FirstOrDefaultAsync(info => info.Id == updateTankInput.Id);
  88. if (fccTankInfo == null)
  89. {
  90. Logger.Info($"find tank info with id : {updateTankInput.Id} for update,result is null");
  91. return 0;
  92. }
  93. fccTankInfo.Number = updateTankInput.Number;
  94. fccTankInfo.OilId = updateTankInput.OilId;
  95. fccTankInfo.OilName = updateTankInput.OilName;
  96. fccTankInfo.Capacity = updateTankInput.Capacity;
  97. return await _dbContext.SaveChangesAsync();
  98. }
  99. /// <summary>
  100. /// 获取油罐id,油罐号
  101. /// </summary>
  102. /// <returns></returns>
  103. public async Task<List<DetailsNozzleInfoOutput.RelatableTank>> GetTankInfo()
  104. {
  105. return await _dbContext.TankInfos.Select(info => new DetailsNozzleInfoOutput.RelatableTank
  106. {
  107. TankId = info.Id,
  108. TankNum = info.Number
  109. }).ToListAsync();
  110. }
  111. }
  112. }