duheng
2024-12-24 0e33247236d4ac46f1a75802f53dd6c612301cff
Service/HStation.Service.Assets.Core/05-service/04-FourLink/02-FourlinkMain/FourLinkManage.cs
@@ -40,7 +40,7 @@
            {
                model.Reset(model_ds);
            }
            AssetsPumpSeriesCacheHelper.Trigger();
            AssetsFourlinkMainCacheHelper.Trigger();
        }
        //通过 Ids 更新缓存
@@ -59,7 +59,7 @@
            {
                all.AddRange(model_list);
            }
            AssetsPumpSeriesCacheHelper.Trigger();
            AssetsFourlinkMainCacheHelper.Trigger();
        }
        //移除缓存
@@ -67,7 +67,7 @@
        {
            var all = GetCache();
            all.RemoveAll(x => x.ID == ID);
            AssetsPumpSeriesCacheHelper.Trigger();
            AssetsFourlinkMainCacheHelper.Trigger();
        }
        /// <summary>
@@ -75,10 +75,12 @@
        /// </summary>
        public static void PublishCache(string key)
        {
            AssetsPumpSeriesCacheHelper.Publish(key);
            AssetsFourlinkMainCacheHelper.Publish(key);
        }
        #endregion Cache
        #region Query
@@ -88,7 +90,7 @@
        public List<Model.AssetsFourlinkMain> GetAll()
        {
            var all = GetCache();
            return all;
            return all.OrderBy(x => x.SortCode).ToList();
        }
        /// <summary>
@@ -110,28 +112,46 @@
                return default;
            }
            var all = GetAll();
            return all.Where(x => Ids.Contains(x.ID)).ToList();
            return all.Where(x => Ids.Contains(x.ID)).OrderBy(x => x.SortCode).ToList();
        }
        /// <summary>
        /// 通过 系列ID 获取
        /// 获取数量
        /// </summary>
        public List<Model.AssetsFourlinkMain> GetBySeriesID(long id)
        public int GetCount()
        {
            if (id < 1)
            var all = GetAll();
            return all.Count;
        }
        /// <summary>
        /// 通过 SeriesID 获取
        /// </summary>
        public List<Model.AssetsFourlinkMain> GetBySeriesID(long SeriesID)
        {
            var all = GetAll();
            return all.Where(x => x.SeriesID == SeriesID).OrderBy(x => x.SortCode).ToList();
        }
        /// <summary>
        /// 通过 SeriesIds 获取
        /// </summary>
        public List<Model.AssetsFourlinkMain> GetBySeriesIds(List<long> SeriesIds)
        {
            if (SeriesIds == null || SeriesIds.Count < 1)
            {
                return default;
            }
            var all = GetAll();
            return all.Where(x => x.SeriesID == id).ToList();
            return all.Where(x => SeriesIds.Contains(x.SeriesID)).OrderBy(x => x.SortCode).ToList();
        }
        /// <summary>
        /// 获取最大排序码
        /// </summary>
        public int GetMaxSortCode()
        public int GetMaxSortCode(long SeriesID)
        {
            var all = GetAll();
            var all = GetBySeriesID(SeriesID);
            if (all == null || all.Count < 1)
            {
                return 0;
@@ -140,6 +160,8 @@
        }
        #endregion Query
        #region Insert
@@ -183,6 +205,8 @@
        }
        #endregion Insert
        #region Update
@@ -228,8 +252,145 @@
            return bol;
        }
        /// <summary>
        /// 更新排序码
        /// </summary>
        public bool UpdateSortCode(long ID, int SortCode)
        {
            if (ID < 1)
            {
                return false;
            }
            var dal = DALCreateHelper.CreateDAL<HStation.DAL.IAssetsFourlinkMain>();
            var bol = dal.UpdateSortCode(ID, SortCode);
            if (bol)
            {
                UpdateCache(ID);
            }
            return bol;
        }
        /// <summary>
        /// 更新排序
        /// </summary>
        public bool UpdateSorter(List<Yw.Model.Sorter> sorters)
        {
            if (sorters == null || sorters.Count < 1)
            {
                return false;
            }
            if (sorters.Exists(x => x.ID < 1))
            {
                return false;
            }
            var dal = DALCreateHelper.CreateDAL<HStation.DAL.IAssetsFourlinkMain>();
            var bol = dal.UpdateSorter(sorters.ToEntityList());
            if (bol)
            {
                UpdateCache(sorters.Select(x => x.ID).ToList());
            }
            return bol;
        }
        /// <summary>
        /// 更新 Paras
        /// </summary>
        public bool UpdateParas(long ID, Dictionary<string, string> Paras)
        {
            if (ID < 1)
            {
                return false;
            }
            var dal = DALCreateHelper.CreateDAL<HStation.DAL.IAssetsFourlinkMain>();
            var bol = dal.UpdateParas(ID, ParasHelper.ToString(Paras));
            if (bol)
            {
                UpdateCache(ID);
            }
            return bol;
        }
        /// <summary>
        /// 更新 Flags
        /// </summary>
        public bool UpdateFlags(long ID, List<string> Flags)
        {
            if (ID < 1)
            {
                return false;
            }
            var dal = DALCreateHelper.CreateDAL<HStation.DAL.IAssetsFourlinkMain>();
            var bol = dal.UpdateFlags(ID, FlagsHelper.ToString(Flags));
            if (bol)
            {
                UpdateCache(ID);
            }
            return bol;
        }
        /// <summary>
        /// 更新 TagName
        /// </summary>
        public bool UpdateTagName(long ID, string TagName)
        {
            if (ID < 1)
            {
                return false;
            }
            var dal = DALCreateHelper.CreateDAL<HStation.DAL.IAssetsFourlinkMain>();
            var bol = dal.UpdateTagName(ID, TagName);
            if (bol)
            {
                UpdateCache(ID);
            }
            return bol;
        }
        #endregion Update
        #region Exist
        /// <summary>
        /// 判断 TagName 是否存在
        /// </summary>
        public bool IsExistTagName(string TagName)
        {
            if (string.IsNullOrEmpty(TagName))
            {
                return false;
            }
            var all = GetAll();
            return all.Exists(x => x.TagName == TagName);
        }
        /// <summary>
        /// 判断 TagName 是否存在 ExceptID
        /// </summary>
        public bool IsExistTagNameExceptID(string TagName, long ExceptID)
        {
            if (string.IsNullOrEmpty(TagName))
            {
                return false;
            }
            var all = GetAll();
            return all.Exists(x => x.TagName == TagName && x.ID != ExceptID);
        }
        /// <summary>
        /// 通过 SeriesID 判断是否存在
        /// </summary>
        public bool IsExistBySeriesID(long SeriesID)
        {
            var all = GetAll();
            return all.Exists(x => x.SeriesID == SeriesID);
        }
        #endregion Exist
        #region Delete
        /// <summary>