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;
}
}
}