using System.Collections.Generic;
|
using System.Linq;
|
|
namespace IStation.BLL
|
{
|
/// <summary>
|
/// 测点映射
|
/// </summary>
|
public partial class EquipmentMonitorMapping
|
{
|
private readonly DAL.EquipmentMonitorMapping _dal = new DAL.EquipmentMonitorMapping();
|
|
#region Cache
|
|
// 获取缓存
|
private List<Model.EquipmentMonitorMapping> GetCache()
|
{
|
return CacheHelper<Model.EquipmentMonitorMapping>.GetSet(Settings.Project.ID, () =>
|
{
|
var entities = _dal.GetAll();
|
var models = Entity2Models(entities);
|
if (models == null)
|
{
|
models = new List<Model.EquipmentMonitorMapping>();
|
}
|
return models;
|
}, ConfigHelper.CacheKeepTime, ConfigHelper.CacheRandomTime);
|
}
|
|
// 更新缓存
|
private void UpdateCache(long id)
|
{
|
if (id < 1)
|
return;
|
var entities = _dal.GetByID(id);
|
var models = Entity2Model(entities);
|
var all = GetCache();
|
var model = all.Find(x => x.ID == id);
|
if (model == null)
|
{
|
all.Add(models);
|
}
|
else
|
{
|
model.Reset(models);
|
}
|
}
|
|
// 更新缓存
|
private void UpdateCache(List<long> ids)
|
{
|
if (ids == null || ids.Count() < 1)
|
return;
|
var entities = _dal.GetByIds(ids);
|
var models = Entity2Models(entities);
|
var all = GetCache();
|
all.RemoveAll(x => ids.Contains(x.ID));
|
if (models != null && models.Count > 0)
|
{
|
all.AddRange(models);
|
}
|
}
|
|
|
//通过 EquipmentID 更新缓存
|
private void UpdateCacheByEquipmentID(long equipmentId)
|
{
|
var entities = _dal.GetByEquipmentID(equipmentId);
|
var models = Entity2Models(entities);
|
var all = GetCache();
|
all.RemoveAll(x => x.EquipmentID == equipmentId);
|
if (models != null && models.Count > 0)
|
{
|
all.AddRange(models);
|
}
|
}
|
|
|
// 移除缓存
|
private void RemoveCache(long id)
|
{
|
if (id < 1)
|
return;
|
var all = GetCache();
|
all.RemoveAll(x => x.ID == id);
|
}
|
|
// 移除缓存
|
private void RemoveCache(List<long> ids)
|
{
|
if (ids == null || ids.Count() < 1)
|
return;
|
var all = GetCache();
|
all.RemoveAll(x => ids.Contains(x.ID));
|
}
|
|
//通过 EquipmentID 移除缓存
|
private void RemoveCacheByEquipmentID(long equipmentId)
|
{
|
if (equipmentId < 1)
|
return;
|
var all = GetCache();
|
all.RemoveAll(x => x.EquipmentID == equipmentId);
|
}
|
|
|
//通过 EquipmentIds 移除缓存
|
private void RemoveCacheByEquipmentIds(List<long> equipmentIds)
|
{
|
if (equipmentIds == null || equipmentIds.Count < 1)
|
return;
|
var all = GetCache();
|
all.RemoveAll(x => equipmentIds.Contains(x.EquipmentID));
|
}
|
|
#endregion
|
|
#region Get
|
|
/// <summary>
|
/// 查询全部
|
/// </summary>
|
public List<Model.EquipmentMonitorMapping> GetAll()
|
{
|
var all = GetCache();
|
return all.ToList();
|
}
|
|
/// <summary>
|
/// 根据 ID查询
|
/// </summary>
|
public Model.EquipmentMonitorMapping GetByID(long id)
|
{
|
var all = GetAll();
|
return all.Find(x => x.ID == id);
|
}
|
|
/// <summary>
|
/// 根据 Ids 查询
|
/// </summary>
|
public List<Model.EquipmentMonitorMapping> GetByIds(List<long> ids)
|
{
|
if (ids == null || ids.Count() < 1)
|
return default;
|
var all = GetAll();
|
return all.Where(x => ids.Contains(x.ID)).ToList();
|
}
|
|
/// <summary>
|
/// 根据 EquipmentID 查询
|
/// </summary>
|
public List<Model.EquipmentMonitorMapping> GetByEquipmentID(long equipmentId)
|
{
|
var all = GetAll();
|
return all.Where(x => x.EquipmentID == equipmentId).ToList();
|
}
|
|
/// <summary>
|
/// 根据 EquipmentIds 查询
|
/// </summary>
|
public List<Model.EquipmentMonitorMapping> GetByEquipmentIds(List<long> equipmentIds)
|
{
|
if (equipmentIds == null || equipmentIds.Count < 1)
|
return default;
|
var all = GetAll();
|
return all.Where(x => equipmentIds.Contains(x.EquipmentID)).ToList();
|
}
|
|
#endregion
|
|
#region Insert
|
|
/// <summary>
|
/// 插入
|
/// </summary>
|
public long Insert(Model.EquipmentMonitorMapping model)
|
{
|
if (model == null)
|
return default;
|
var entity = Model2Entity(model);
|
var ID = _dal.Insert(entity);
|
if (ID > 0)
|
{
|
UpdateCache(ID);
|
}
|
return ID;
|
}
|
|
/// <summary>
|
/// 批量插入
|
/// </summary>
|
public bool Inserts(List<Model.EquipmentMonitorMapping> models)
|
{
|
if (models == null || models.Count() < 1)
|
return default;
|
var entities = Model2Entities(models.ToList());
|
var ids = _dal.InsertsR(entities);
|
if (ids != null && ids.Count > 0)
|
{
|
UpdateCache(ids);
|
return true;
|
}
|
return false;
|
}
|
|
#endregion
|
|
#region Update
|
|
/// <summary>
|
/// 更新
|
/// </summary>
|
public bool Update(Model.EquipmentMonitorMapping model)
|
{
|
if (model == null)
|
return default;
|
if (model.ID < 1)
|
return default;
|
var entity = Model2Entity(model);
|
var bol = _dal.Update(entity);
|
if (bol)
|
{
|
UpdateCache(model.ID);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 批量更新
|
/// </summary>
|
public bool Updates(List<Model.EquipmentMonitorMapping> models)
|
{
|
if (models == null || models.Count() < 1)
|
return default;
|
if (models.ToList().Exists(x => x.ID < 1))
|
return default;
|
var entities = Model2Entities(models.ToList());
|
var bol = _dal.Updates(entities);
|
if (bol)
|
{
|
UpdateCache(models.Select(x => x.ID).ToList());
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Set
|
|
/// <summary>
|
/// 设置
|
/// </summary>
|
public bool SetOfMapping(long equipmentId, List<Model.EquipmentMonitorMapping> list)
|
{
|
List<Entity.EquipmentMonitorMapping> entities = null;
|
if (list != null && list.Any())
|
{
|
entities = Model2Entities(list);
|
}
|
var bol = _dal.SetOfObject(equipmentId, entities);
|
if (bol)
|
{
|
UpdateCacheByEquipmentID(equipmentId);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Exist
|
|
/// <summary>
|
/// 根据 ID 判断是否存在
|
/// </summary>
|
public bool IsExistByID(long id)
|
{
|
var all = GetAll();
|
return all.Exists(x => x.ID == id);
|
}
|
|
/// <summary>
|
/// 通过 MonitorPointID 判断是否存在
|
/// </summary>
|
public bool IsExistByMonitorPointID(long monitorPointID)
|
{
|
if (monitorPointID < 1)
|
return default;
|
var all = GetAll();
|
if (all == null || all.Count < 1)
|
return default;
|
return all.Exists(x => x.MonitorPointID == monitorPointID);
|
}
|
|
#endregion
|
|
#region Delete
|
|
/// <summary>
|
/// 通过ID删除
|
/// </summary>
|
public bool DeleteByID(long id, out string msg)
|
{
|
msg = string.Empty;
|
var bol = _dal.DeleteByID(id);
|
if (bol)
|
{
|
RemoveCache(id);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 通过 EquipmentID 删除
|
/// </summary>
|
public bool DeleteByEquipmentID(long equipmentId, out string msg)
|
{
|
msg = string.Empty;
|
var bol = _dal.DeleteByEquipmentID(equipmentId);
|
if (bol)
|
{
|
RemoveCacheByEquipmentID(equipmentId);
|
}
|
return bol;
|
}
|
|
|
/// <summary>
|
/// 通过 EquipmentIds 删除
|
/// </summary>
|
public bool DeleteByEquipmentIds(List<long> equipmentIds, out string msg)
|
{
|
msg = string.Empty;
|
if (equipmentIds == null || equipmentIds.Count() < 1)
|
{
|
msg = "equipmentIds is null";
|
return false;
|
}
|
var bol = _dal.DeleteByEquipmentIds(equipmentIds);
|
if (bol)
|
{
|
RemoveCacheByEquipmentIds(equipmentIds);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Cover
|
|
/// <summary>
|
/// 批量覆盖
|
/// </summary>
|
public bool Covers(List<Model.EquipmentMonitorMapping> models)
|
{
|
if (models == null || models.Count() < 1)
|
return default;
|
var entities = Model2Entities(models);
|
var bol = _dal.Covers(entities);
|
if (bol)
|
{
|
CacheHelper<Model.EquipmentMonitorMapping>.Remove(Settings.Project.ID);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
}
|
}
|