using System;
|
using System.Collections.Generic;
|
using System.Linq;
|
using System.Text;
|
using System.Threading.Tasks;
|
|
namespace IStation.BLL
|
{
|
/// <summary>
|
/// 测点映射
|
/// </summary>
|
public partial class MonitorPointMapping
|
{
|
private readonly IDAL.IMonitorPointMapping<Entity.MonitorPointMapping> _dal
|
= DAL.Factory.DataAccess.CreateDAL<IDAL.IMonitorPointMapping<Entity.MonitorPointMapping>>(Settings.DataAccess.MonitorDLLName, Settings.DataAccess.DALNameSpace);
|
|
#region Cache
|
|
//根据 projectId 查询缓存
|
private List<Model.MonitorPointMapping> GetProjectCache(long projectId)
|
{
|
return MonitorPointMappingCacheHelper.GetSet(projectId, () =>
|
{
|
var entities = _dal.GetAll(projectId);
|
var models = Entity2Models(entities);
|
if (models == null)
|
{
|
models = new List<Model.MonitorPointMapping>();
|
}
|
return models;
|
}, ConfigHelper.CacheKeepTime, ConfigHelper.CacheRandomTime);
|
}
|
|
//根据 Id 更新缓存
|
private void UpdateProjectCache(long projectId, long Id)
|
{
|
var entity_ds = _dal.GetById(projectId, Id);
|
var model_ds = Entity2Model(entity_ds);
|
var all = GetProjectCache(projectId);
|
var model = all.Find(x => x.Id == Id);
|
if (model == null)
|
{
|
all.Add(model_ds);
|
}
|
else
|
{
|
model.Reset(model_ds);
|
}
|
}
|
|
//根据 Ids 更新缓存
|
private void UpdateProjectCache(long projectId, IEnumerable<long> Ids)
|
{
|
if (Ids == null || Ids.Count() < 1)
|
return;
|
var entities = _dal.GetByIds(projectId, Ids);
|
var models = Entity2Models(entities);
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => Ids.Contains(x.Id));
|
if (models != null && models.Count > 0)
|
{
|
all.AddRange(models);
|
}
|
}
|
|
//根据 MonitorPointId 更新缓存
|
private void UpdateProjectCacheByMonitorPointId(long projectId, long monitorPointId)
|
{
|
var entity_list = _dal.GetByMonitorPointId(projectId, monitorPointId);
|
var model_list = Entity2Models(entity_list);
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => x.MonitorPointId == monitorPointId);
|
if (model_list != null && model_list.Count > 0)
|
{
|
all.AddRange(model_list);
|
}
|
}
|
|
//根据 ObjectType 和 ObjectId 更新缓存
|
private void UpdateProjectCacheByObjectTypeAndObjectId(long projectId, string objectType, long objectId)
|
{
|
var entity_list = _dal.GetByObjectTypeAndObjectId(projectId, objectType, objectId);
|
var model_list = Entity2Models(entity_list);
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => x.ObjectType == objectType && x.ObjectId == objectId);
|
if (model_list != null && model_list.Count > 0)
|
{
|
all.AddRange(model_list);
|
}
|
}
|
|
//根据 Id 移除缓存
|
private void RemoveProjectCache(long projectId, long Id)
|
{
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => x.Id == Id);
|
}
|
|
//根据 Ids 移除缓存
|
internal void RemoveProjectCache(long projectId, IEnumerable<long> Ids)
|
{
|
if (Ids == null || Ids.Count() < 1)
|
return;
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => Ids.Contains(x.Id));
|
|
}
|
|
//根据 MonitorPointId 移除缓存
|
internal void RemoveProjectCacheByMonitorPointId(long projectId, long monitorPointId)
|
{
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => x.MonitorPointId == monitorPointId);
|
|
}
|
|
//根据 ObjectType 和 ObjectId 更新缓存
|
private void RemoveProjectCacheByObjectTypeAndObjectId(long projectId, string objectType, long objectId)
|
{
|
var all = GetProjectCache(projectId);
|
all.RemoveAll(x => x.ObjectType == objectType && x.ObjectId == objectId);
|
}
|
|
#endregion
|
|
#region Get
|
|
/// <summary>
|
/// 查询全部
|
/// </summary>
|
public List<Model.MonitorPointMapping> GetAll(long projectId)
|
{
|
var all = GetProjectCache(projectId);
|
return all.OrderBy(x => x.SortCode).ToList();
|
}
|
|
/// <summary>
|
/// 根据 Id查询
|
/// </summary>
|
public Model.MonitorPointMapping GetById(long projectId, long Id)
|
{
|
var all = GetAll(projectId);
|
return all.Find(x => x.Id == Id);
|
}
|
|
/// <summary>
|
/// 根据 Ids 查询
|
/// </summary>
|
public List<Model.MonitorPointMapping> GetByIds(long projectId, IEnumerable<long> Ids)
|
{
|
if (Ids == null || Ids.Count() < 1)
|
return default;
|
var all = GetAll(projectId);
|
return all.Where(x => Ids.Contains(x.Id)).ToList();
|
}
|
|
/// <summary>
|
/// 根据 MonitorPointId 查询
|
/// </summary>
|
public List<Model.MonitorPointMapping> GetByMonitorPointId(long projectId, long monitorPointId)
|
{
|
var all = GetAll(projectId);
|
return all.Where(x => x.MonitorPointId == monitorPointId).OrderBy(x => x.SortCode).ToList();
|
}
|
|
/// <summary>
|
/// 根据 ObjectType 和 ObjectId 查询
|
/// </summary>
|
public List<Model.MonitorPointMapping> GetByObjectTypeAndObjectId(long projectId, string objectType, long objectId)
|
{
|
var all = GetAll(projectId);
|
return all.Where(x => x.ObjectType == objectType && x.ObjectId == objectId).OrderBy(x => x.SortCode).ToList();
|
}
|
|
/// <summary>
|
/// 根据 ObjectType 和 ObjectIds 查询
|
/// </summary>
|
public List<Model.MonitorPointMapping> GetByObjectTypeAndObjectIds(long projectId, string objectType, List<long> objectIds)
|
{
|
if (objectIds == null || objectIds.Count() < 1)
|
return default;
|
var all = GetAll(projectId);
|
return all.Where(x => x.ObjectType == objectType && objectIds.Contains(x.ObjectId)).OrderBy(x => x.SortCode).ToList();
|
}
|
|
#endregion
|
|
#region Insert
|
|
/// <summary>
|
/// 插入
|
/// </summary>
|
public long Insert(long projectId, Model.MonitorPointMapping model)
|
{
|
if (projectId < 1)
|
return default;
|
if (model == null)
|
return default;
|
var entities = Model2Entity(model);
|
var Id = _dal.Insert(projectId, entities);
|
if (Id > 0)
|
{
|
UpdateProjectCache(projectId, Id);
|
}
|
return Id;
|
}
|
|
/// <summary>
|
/// 批量插入
|
/// </summary>
|
public bool Inserts(long projectId, IEnumerable<Model.MonitorPointMapping> list)
|
{
|
if (projectId < 1)
|
return default;
|
if (list == null || list.Count() < 1)
|
return default;
|
var entities = Model2Entities(list.ToList());
|
var Ids = _dal.InsertsR(projectId, entities);
|
if (Ids != null && Ids.Count > 0)
|
{
|
UpdateProjectCache(projectId, Ids);
|
return true;
|
}
|
return false;
|
}
|
|
#endregion
|
|
#region Update
|
|
/// <summary>
|
/// 更新
|
/// </summary>
|
public bool Update(long projectId, Model.MonitorPointMapping model)
|
{
|
if (projectId < 1)
|
return default;
|
if (model == null)
|
return default;
|
if (model.Id < 1)
|
return default;
|
var entities = Model2Entity(model);
|
var bol = _dal.Update(projectId, entities);
|
if (bol)
|
{
|
UpdateProjectCache(projectId, model.Id);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 批量更新
|
/// </summary>
|
public bool Updates(long projectId, List<Model.MonitorPointMapping> list)
|
{
|
if (projectId < 1)
|
return default;
|
if (list == null || list.Count() < 1)
|
return default;
|
if (list.ToList().Exists(x => x.Id < 1))
|
return default;
|
var entities = Model2Entities(list.ToList());
|
var bol = _dal.Updates(projectId, entities);
|
if (bol)
|
{
|
UpdateProjectCache(projectId, list.Select(x => x.Id).ToList());
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Set
|
|
/// <summary>
|
/// 设置Object测点映射
|
/// </summary>
|
public bool SetOfObject(long projectId, string objectType, long objectId, List<Model.MonitorPointMapping> list)
|
{
|
var entities = Model2Entities(list.ToList());
|
var bol = _dal.SetOfObject(projectId, objectType, objectId, entities);
|
if (bol)
|
{
|
UpdateProjectCacheByObjectTypeAndObjectId(projectId, objectType, objectId);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Exist
|
|
/// <summary>
|
/// 根据 Id 判断是否存在
|
/// </summary>
|
public bool IsExistById(long projectId, long Id)
|
{
|
var all = GetAll(projectId);
|
return all.Exists(x => x.Id == Id);
|
}
|
|
/// <summary>
|
/// 根据 MonitorPointId 判断是否存在
|
/// </summary>
|
public bool IsExistByMonitorPointId(long projectId, long monitorPointId)
|
{
|
var all = GetAll(projectId);
|
return all.Exists(x => x.MonitorPointId == monitorPointId);
|
}
|
|
/// <summary>
|
/// 根据 ObjectType 和 ObjectId 判断是否存在
|
/// </summary>
|
public bool IsExistByObjectTypeAndObjectId(long projectId, string objectType, long objectId)
|
{
|
var all = GetAll(projectId);
|
return all.Exists(x => x.ObjectType == objectType && x.ObjectId == objectId);
|
}
|
#endregion
|
|
#region Delete
|
|
/// <summary>
|
/// 根据 Id 删除
|
/// </summary>
|
public bool DeleteById(long projectId, long Id, out string msg)
|
{
|
msg = string.Empty;
|
var bol = _dal.DeleteById(projectId, Id);
|
if (bol)
|
{
|
RemoveProjectCache(projectId, Id);
|
}
|
return bol;
|
}
|
|
|
/// <summary>
|
/// 根据 Ids 删除
|
/// </summary>
|
public bool DeleteByIds(long projectId, List<long> Ids, out string msg)
|
{
|
msg = string.Empty;
|
if (Ids == null || Ids.Count() < 1)
|
return default;
|
var bol = _dal.DeleteByIds(projectId, Ids);
|
if (bol)
|
{
|
RemoveProjectCache(projectId, Ids);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 根据 MonitorPointId 删除
|
/// </summary>
|
public bool DeleteByMonitorPointId(long projectId, long monitorPointId, out string msg)
|
{
|
msg = string.Empty;
|
var bol = _dal.DeleteByMonitorPointId(projectId, monitorPointId);
|
if (bol)
|
{
|
RemoveProjectCacheByMonitorPointId(projectId, monitorPointId);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 根据 ObjectType 和 ObjectId 删除
|
/// </summary>
|
public bool DeleteByObjectTypeAndObjectID(long projectId, string objectType, long objectId, out string msg)
|
{
|
msg = string.Empty;
|
var bol = _dal.DeleteByObjectTypeAndObjectId(projectId, objectType, objectId);
|
if (bol)
|
{
|
RemoveProjectCacheByObjectTypeAndObjectId(projectId, objectType, objectId);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Cover
|
|
/// <summary>
|
/// 批量覆盖
|
/// </summary>
|
public bool Covers(long projectId, IEnumerable<Model.MonitorPointMapping> list)
|
{
|
if (projectId < 1)
|
return default;
|
if (list == null || list.Count() < 1)
|
return default;
|
var entities = Model2Entities(list.ToList());
|
var bol = _dal.Covers(projectId, entities);
|
if (bol)
|
{
|
MonitorPointMappingCacheHelper.Remove(projectId);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 批量覆盖并返回
|
/// </summary>
|
public List<Entity.MonitorPointMapping> CoversR(long projectId, IEnumerable<Model.MonitorPointMapping> list)
|
{
|
if (projectId < 1)
|
return default;
|
if (list == null || list.Count() < 1)
|
return default;
|
var entities = Model2Entities(list.ToList());
|
var models = _dal.CoversR(projectId, entities);
|
if (models != null && models.Count > 0)
|
{
|
MonitorPointMappingCacheHelper.Remove(projectId);
|
}
|
return models;
|
}
|
|
#endregion
|
}
|
}
|