using Infrastructure.Attribute; using Infrastructure.Model; using SqlSugar; using System; using System.Collections.Generic; using System.Linq; using ARW.Model; using ARW.Model.System; namespace ARW.Repository.System { /// /// 字典数据 /// [AppService(ServiceLifetime = LifeTime.Transient)] public class SysDictDataRepository : BaseRepository { /// /// 字典类型数据搜索 /// /// /// /// public PagedInfo SelectDictDataList(SysDictData dictData, PagerInfo pagerInfo) { var exp = Expressionable.Create(); exp.AndIF(!string.IsNullOrEmpty(dictData.DictLabel), it => it.DictLabel.Contains(dictData.DictLabel)); exp.AndIF(!string.IsNullOrEmpty(dictData.Status), it => it.Status == dictData.Status); exp.AndIF(!string.IsNullOrEmpty(dictData.DictType), it => it.DictType == dictData.DictType); return GetPages(exp.ToExpression(), pagerInfo); } /// /// 根据字典类型查询 /// /// /// public List SelectDictDataByType(string dictType) { return Context.Queryable().Where(f => f.Status == "0" && f.DictType == dictType) .OrderBy(it => it.DictSort) .ToList(); } /// /// 根据字典类型查询 /// /// /// public List SelectDictDataByTypes(string[] dictTypes) { return Context.Queryable().Where(f => f.Status == "0" && dictTypes.Contains(f.DictType)) .OrderBy(it => it.DictSort) .ToList(); } /// /// 新增保存字典数据信息 /// /// /// public long InsertDictData(SysDictData dict) { var result = Context.Insertable(dict).ExecuteReturnBigIdentity(); return result; } /// /// 修改数据 /// /// /// public long UpdateDictData(SysDictData dict) { return Context.Updateable() .SetColumns(t => new SysDictData() { Remark = dict.Remark, Update_time = DateTime.Now, DictSort = dict.DictSort, DictLabel = dict.DictLabel, DictValue = dict.DictValue, Status = dict.Status, CssClass = dict.CssClass, ListClass = dict.ListClass }) .Where(f => f.DictCode == dict.DictCode).ExecuteCommand(); } /// /// 批量删除字典数据信息 /// /// /// public int DeleteDictDataByIds(long[] dictCodes) { return Delete(dictCodes); } /// /// 同步修改字典类型 /// /// 旧字典类型 /// 新字典类型 /// public int UpdateDictDataType(string old_dictType, string new_dictType) { //只更新DictType字段根据where条件 return Context.Updateable() .SetColumns(t => new SysDictData() { DictType = new_dictType }) .Where(f => f.DictType == old_dictType) .ExecuteCommand(); } /// /// 获取字典信息名称 /// /// public string GetDictNameByName(string name, string value) { var dictData = Context.Queryable().Where(s => s.DictType == name).ToList(); if (dictData.Count <= 0) throw new Exception(name + "字典不存在"); var res = dictData.Where(s => s.DictValue == value).First(); return res.DictLabel; } /// /// 获取字典值 /// /// public string GetDictValueByName(string name, string lable) { var dictData = Context.Queryable().Where(s => s.DictType == name).ToList(); if (dictData.Count <= 0) throw new Exception(name + "字典不存在"); var res = dictData.Where(s => s.DictLabel == lable).First(); return res.DictValue; } } }