namespace ISupply.BLL
|
{
|
/// <summary>
|
/// Facilities
|
/// </summary>
|
public partial class Facilities
|
{
|
private readonly DAL.Facilities _dal = new DAL.Facilities();
|
|
#region Cache
|
|
//根据 查询缓存
|
private List<Model.Facilities> GetCache()
|
{
|
return FacilitiesCacheHelper.GetSet(() =>
|
{
|
var entities = _dal.GetAll();
|
var models = Entity2Models(entities);
|
if (models == null)
|
{
|
models = new List<Model.Facilities>();
|
}
|
return models;
|
}, ConfigHelper.CacheKeepTime, ConfigHelper.CacheRandomTime);
|
}
|
|
//根据 ID 更新缓存
|
private void UpdateCache(long id)
|
{
|
var entity_ds = _dal.GetByID(id);
|
var model_ds = Entity2Model(entity_ds);
|
var all = GetCache();
|
var model = all.Find(x => x.ID == id);
|
if (model == null)
|
{
|
all.Add(model_ds);
|
}
|
else
|
{
|
model.Reset(model_ds);
|
}
|
}
|
|
//根据 Ids 更新缓存
|
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);
|
}
|
}
|
|
//根据 ID 移除缓存
|
private void RemoveCache(long id)
|
{
|
var all = GetCache();
|
all.RemoveAll(x => x.ID == id);
|
}
|
|
#endregion
|
|
#region Get
|
|
/// <summary>
|
/// 查询全部
|
/// </summary>
|
public List<Model.Facilities> GetAll()
|
{
|
var all = GetCache();
|
return all.OrderBy(x => x.SortCode).ToList();
|
}
|
|
/// <summary>
|
/// 根据 ID 查询
|
/// </summary>
|
public Model.Facilities GetByID(long id)
|
{
|
var all = GetAll();
|
return all.Find(x => x.ID == id);
|
}
|
|
/// <summary>
|
/// 根据 Ids 查询
|
/// </summary>
|
public List<Model.Facilities> 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>
|
/// 根据 BuildingID 查询
|
/// </summary>
|
public List<Model.Facilities> GetByBuildingID(long id)
|
{
|
var all = GetAll();
|
return all.Where(x => x.BuildingID == id).ToList();
|
}
|
|
/// <summary>
|
/// 根据 BuildingIds 查询
|
/// </summary>
|
public List<Model.Facilities> GetByBuildingIds(List<long> buildingIds)
|
{
|
if (buildingIds == null || !buildingIds.Any())
|
return default;
|
var all = GetAll();
|
return all.Where(x => buildingIds.Contains(x.BuildingID)).ToList();
|
}
|
|
#endregion
|
|
#region Insert
|
|
/// <summary>
|
/// 插入
|
/// </summary>
|
public long Insert(Model.Facilities 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.Facilities> list)
|
{
|
if (list == null || list.Count() < 1)
|
return default;
|
var entities = Model2Entities(list.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.Facilities 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.Facilities> list)
|
{
|
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(entities);
|
if (bol)
|
{
|
UpdateCache(list.Select(x => x.ID).ToList());
|
}
|
return bol;
|
}
|
|
|
/// <summary>
|
/// 更新排序码
|
/// </summary>
|
public bool UpdateSortCode(long id, int sortCode)
|
{
|
if (id < 1)
|
return false;
|
var bol = _dal.UpdateSortCode(id, sortCode);
|
if (bol)
|
{
|
UpdateCache(id);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 更新排序
|
/// </summary>
|
public virtual bool UpdateSorter(List<Yw.Model.Sorter> sorters)
|
{
|
if (sorters == null || sorters.Count() < 1)
|
return default;
|
if (sorters.Exists(x => x.ID < 1))
|
return default;
|
var models = sorters.Model2Entities();
|
var bol = _dal.UpdateSorter(models);
|
if (bol)
|
{
|
var ids = models.Select(x => x.ID).ToList();
|
UpdateCache(ids);
|
}
|
return bol;
|
}
|
|
|
/// <summary>
|
/// 更新 Flags
|
/// </summary>
|
public virtual bool UpdateFlags(long id, List<string> flagsList)
|
{
|
if (id < 1)
|
return false;
|
var flags = FlagsHelper.ToString(flagsList);
|
var bol = _dal.UpdateFlags(id, flags);
|
if (bol)
|
{
|
UpdateCache(id);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 更新 TagName
|
/// </summary>
|
public bool UpdateTagName(long id, string tagName)
|
{
|
if (id < 1)
|
return false;
|
var bol = _dal.UpdateTagName(id, tagName);
|
if (bol)
|
{
|
UpdateCache(id);
|
}
|
return bol;
|
}
|
|
/// <summary>
|
/// 更新 UseStatus
|
/// </summary>
|
public virtual bool UpdateUseStatus(long id, int useStatus)
|
{
|
if (id < 1)
|
return false;
|
var bol = _dal.UpdateUseStatus(id, useStatus);
|
if (bol)
|
{
|
UpdateCache(id);
|
}
|
return bol;
|
}
|
|
#endregion
|
|
#region Exist
|
|
/// <summary>
|
/// 根据 ID 判断是否存在
|
/// </summary>
|
public bool IsExistByID(long id)
|
{
|
var all = GetAll();
|
return all.Exists(x => x.ID == id);
|
}
|
|
/// <summary>
|
/// 判断TagName是否存在
|
/// </summary>
|
public bool IsExistTagName(string tangName)
|
{
|
if (string.IsNullOrEmpty(tangName))
|
return default;
|
var all = GetAll();
|
if (all == null || all.Count < 1)
|
return default;
|
return all.Exists(x => !string.IsNullOrEmpty(x.TagName) && x.TagName.ToUpper() == tangName.ToUpper());
|
}
|
|
/// <summary>
|
/// 判断TagName是否存在 ExceptID
|
/// </summary>
|
public bool IsExistTagNameExceptID(string tagName, long exceptID)
|
{
|
if (string.IsNullOrEmpty(tagName))
|
return default;
|
var all = GetAll();
|
if (all == null || all.Count < 1)
|
return default;
|
return all.Exists(x => !string.IsNullOrEmpty(x.TagName) && x.TagName.ToUpper() == tagName.ToUpper() && x.ID != exceptID);
|
}
|
|
#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;
|
}
|
|
#endregion
|
|
}
|
}
|