namespace Yw.Service { /// /// /// public partial class PumpCurveMapping { #region Cache //获取缓存 private static List GetCache() { var all = PumpCurveMappingCacheHelper.GetSet(() => { var dal = new DAL.PumpCurveMapping(); var entityList = dal.GetAll(); var modelList = Entity2Models(entityList); if (modelList == null) { modelList = new List(); } return modelList; }, ConfigHelper.CacheKeepTime, ConfigHelper.CacheRandomTime); return all; } //通过 ID 更新缓存 internal static Model.PumpCurveMapping UpdateCache(long ID) { var dal = new DAL.PumpCurveMapping(); var entityDb = dal.GetByID(ID); var modelDb = Entity2Model(entityDb); var all = GetCache(); var model = all.Find(x => x.ID == ID); if (model == null) { all.Add(modelDb); } else { model.Reset(modelDb); } PumpCurveMappingCacheHelper.Trigger(); return modelDb; } //通过 Ids 更新缓存 private static void UpdateCache(List Ids) { if (Ids == null || Ids.Count < 1) return; var dal = new DAL.PumpCurveMapping(); var entityList = dal.GetByIds(Ids); var modelList = Entity2Models(entityList); var all = GetCache(); all.RemoveAll(x => Ids.Contains(x.ID)); if (modelList != null && modelList.Count > 0) { all.AddRange(modelList); } PumpCurveMappingCacheHelper.Trigger(); } //通过 PumpID 更新缓存 internal static void UpdateCacheByPumpID(long PumpID) { var dal = new DAL.PumpCurveMapping(); var entityList = dal.GetByPumpID(PumpID); var modelList = Entity2Models(entityList); var all = GetCache(); all.RemoveAll(x => x.PumpID == PumpID); if (modelList != null && modelList.Count > 0) { all.AddRange(modelList); } PumpCurveMappingCacheHelper.Trigger(); } //通过 PumpIds 更新缓存 internal static void UpdateCacheByPumpID(List PumpIds) { if (PumpIds == null || PumpIds.Count < 1) { return; } var dal = new DAL.PumpCurveMapping(); var entityList = dal.GetByPumpIds(PumpIds); var modelList = Entity2Models(entityList); var all = GetCache(); all.RemoveAll(x => PumpIds.Contains(x.PumpID)); if (modelList != null && modelList.Count > 0) { all.AddRange(modelList); } PumpCurveMappingCacheHelper.Trigger(); } //通过 CurveID 更新缓存 internal static void UpdateCacheByCurveID(long CurveID) { var dal = new DAL.PumpCurveMapping(); var entityList = dal.GetByCurveID(CurveID); var modelList = Entity2Models(entityList); var all = GetCache(); all.RemoveAll(x => x.CurveID == CurveID); if (modelList != null && modelList.Count > 0) { all.AddRange(modelList); } PumpCurveMappingCacheHelper.Trigger(); } //移除缓存 private static void RemoveCache(long ID) { var all = GetCache(); all.RemoveAll(x => x.ID == ID); PumpCurveMappingCacheHelper.Trigger(); } //通过 PumpID 移除缓存 internal static void RemoveCacheByPumpID(long PumpID) { var all = GetCache(); all.RemoveAll(x => x.PumpID == PumpID); PumpCurveMappingCacheHelper.Trigger(); } //通过 CurveID 移除缓存 internal static void RemoveCacheByCurveID(long CurveID) { var all = GetCache(); all.RemoveAll(x => x.CurveID == CurveID); PumpCurveMappingCacheHelper.Trigger(); } #endregion #region Query /// /// 获取所有 /// public List GetAll() { var all = GetCache(); return all.OrderBy(x => x.SortCode).ToList(); } /// /// 通过 ID 获取 /// public Model.PumpCurveMapping GetByID(long ID) { var all = GetAll(); return all.Find(x => x.ID == ID); } /// /// 通过 ID 获取 /// public List GetByIds(List Ids) { if (Ids == null || Ids.Count < 1) { return default; } var all = GetAll(); return all.Where(x => Ids.Contains(x.ID)).OrderBy(x => x.SortCode).ToList(); } /// /// 通过 PumpID 获取 /// public List GetByPumpID(long PumpID) { var all = GetAll(); return all.Where(x => x.PumpID == PumpID).OrderBy(x => x.SortCode).ToList(); } /// /// 通过 CurveID 获取 /// public List GetByCurveID(long CurveID) { var all = GetAll(); return all.Where(x => x.CurveID == CurveID).ToList(); } /// /// 通过 PumpID 获取工作曲线 /// public Model.PumpCurveMapping GetWorkingByPumpID(long PumpID) { var all = GetByPumpID(PumpID); if (all == null || all.Count < 1) { return default; } return all.Find(x => x.IsWorking); } /// /// 通过 PumpID 获取默认 /// public Model.PumpCurveMapping GetDefaultByPumpID(long PumpID) { var all = GetByPumpID(PumpID); if (all == null || all.Count < 1) { return default; } var model = all.Find(x => x.IsWorking); if (model == null) { model = all.First(); } return model; } /// /// 通过 PumpID 获取最大排序码 /// public int GetMaxSortCodeByPumpID(long PumpID) { var all = GetByPumpID(PumpID); if (all == null || all.Count < 1) { return 0; } return all.Max(x => x.SortCode); } #endregion #region Insert /// /// 添加一条 /// public long Insert(Model.PumpCurveMapping model) { if (model == null) { return default; } if (IsExistByPumpIDAndCurveID(model.PumpID, model.CurveID)) { return default; } var entity = Model2Entity(model); var dal = new DAL.PumpCurveMapping(); var id = dal.Insert(entity); if (id > 0) { UpdateCacheByPumpID(model.PumpID); } return id; } #endregion #region Update /// /// 更新一条 /// public bool Update(Model.PumpCurveMapping model) { if (model == null) { return false; } var entity = Model2Entity(model); var dal = new DAL.PumpCurveMapping(); var bol = dal.Update(entity); if (bol) { UpdateCacheByPumpID(model.PumpID); } return bol; } /// /// 更新排序码 /// public bool UpdateSortCode(long ID, int SortCode) { if (ID < 1) { return default; } var dal = new DAL.PumpCurveMapping(); var bol = dal.UpdateSortCode(ID, SortCode); if (bol) { UpdateCache(ID); } return bol; } /// /// 更新排序 /// public bool UpdateSorter(List sorters) { if (sorters == null || sorters.Count < 1) { return default; } var dal = new DAL.PumpCurveMapping(); var bol = dal.UpdateSorter(sorters.ToEntityList()); if (bol) { UpdateCache(sorters.Select(x => x.ID).ToList()); } return bol; } #endregion #region Exist /// /// 通过 CurveID 判断是否存在 /// public bool IsExistByCurveID(long CurveID) { var all = GetAll(); return all.Exists(x => x.CurveID == CurveID); } /// /// 通过 PumpID 判断是否存在 /// public bool IsExistByPumpID(long PumpID) { var all = GetAll(); return all.Exists(x => x.PumpID == PumpID); } /// /// 通过 PumpID 和 CurveID 判断是否存在 /// public bool IsExistByPumpIDAndCurveID(long PumpID, long CurveID) { var all = GetAll(); return all.Exists(x => x.PumpID == PumpID && x.CurveID == CurveID); } #endregion #region Delete /// /// 通过 ID 删除 /// public bool DeleteByID(long ID, out string Msg) { Msg = string.Empty; var dal = new DAL.PumpCurveMapping(); var bol = dal.DeleteByID(ID); if (bol) { RemoveCache(ID); } return bol; } /// /// 通过 ID 删除(如果曲线没有其他关联关系,则同时删除曲线) /// public bool DeleteExByID(long ID, out string Msg) { Msg = string.Empty; var mapping = GetByID(ID); if (mapping == null) { Msg = "数据不存在"; return false; } var mappingList = GetByCurveID(mapping.CurveID); if (mappingList.Count > 1) { return DeleteByID(ID, out Msg); } return new PumpCurve().DeleteExByID(mapping.CurveID, out Msg); } #endregion #region Set /// /// 设置工作曲线 /// public bool SetWorkingCurve(long ID, out string Msg) { Msg = string.Empty; var model = GetByID(ID); if (model == null) { Msg = "数据不存在"; return false; } var dal = new DAL.PumpCurveMapping(); var bol = dal.SetWorkingCurve(ID, model.PumpID); if (bol) { UpdateCacheByPumpID(model.PumpID); } return bol; } #endregion } }