Files
shgx_tz_mes_backend_sync/ZR.Repository/System/SysDictDataRepository.cs

125 lines
4.3 KiB
C#
Raw Normal View History

2021-08-23 16:57:25 +08:00
using Infrastructure.Attribute;
2021-11-28 11:11:34 +08:00
using Infrastructure.Model;
using SqlSugar;
2021-08-23 16:57:25 +08:00
using System;
using System.Collections.Generic;
2021-12-12 21:03:28 +08:00
using System.Linq;
2021-11-28 11:11:34 +08:00
using ZR.Model;
2021-08-23 16:57:25 +08:00
using ZR.Model.System;
namespace ZR.Repository.System
{
/// <summary>
/// 字典数据
/// </summary>
[AppService(ServiceLifetime = LifeTime.Transient)]
2021-09-27 08:06:09 +08:00
public class SysDictDataRepository : BaseRepository<SysDictData>
2021-08-23 16:57:25 +08:00
{
/// <summary>
/// 字典类型数据搜索
/// </summary>
/// <param name="dictData"></param>
2021-11-28 11:11:34 +08:00
/// <param name="pagerInfo"></param>
2021-08-23 16:57:25 +08:00
/// <returns></returns>
2021-11-28 11:11:34 +08:00
public PagedInfo<SysDictData> SelectDictDataList(SysDictData dictData, PagerInfo pagerInfo)
2021-08-23 16:57:25 +08:00
{
2021-11-28 11:11:34 +08:00
var exp = Expressionable.Create<SysDictData>();
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);
2021-08-23 16:57:25 +08:00
}
/// <summary>
/// 根据字典类型查询
/// </summary>
/// <param name="dictData"></param>
/// <returns></returns>
public List<SysDictData> SelectDictDataByType(string dictType)
{
2021-09-27 08:06:09 +08:00
return Context.Queryable<SysDictData>().Where(f => f.Status == "0" && f.DictType == dictType)
2021-08-23 16:57:25 +08:00
.OrderBy(it => it.DictSort)
.ToList();
}
2021-12-12 21:03:28 +08:00
/// <summary>
/// 根据字典类型查询
/// </summary>
/// <param name="dictData"></param>
/// <returns></returns>
public List<SysDictData> SelectDictDataByTypes(string[] dictTypes)
{
return Context.Queryable<SysDictData>().Where(f => f.Status == "0" && dictTypes.Contains(f.DictType))
.OrderBy(it => it.DictSort)
.ToList();
}
2021-08-23 16:57:25 +08:00
/// <summary>
/// 新增保存字典数据信息
/// </summary>
/// <param name="dict"></param>
/// <returns></returns>
public long InsertDictData(SysDictData dict)
{
2021-10-17 17:35:45 +08:00
var result = Context.Insertable(dict).ExecuteReturnBigIdentity();
2021-08-23 16:57:25 +08:00
return result;
}
/// <summary>
/// 修改数据
/// </summary>
/// <param name="dict"></param>
/// <returns></returns>
public long UpdateDictData(SysDictData dict)
{
2021-09-27 08:06:09 +08:00
return Context.Updateable<SysDictData>()
2021-08-23 16:57:25 +08:00
.SetColumns(t => new SysDictData()
{
Remark = dict.Remark,
Update_time = DateTime.Now,
DictSort = dict.DictSort,
DictLabel = dict.DictLabel,
DictValue = dict.DictValue,
2021-10-09 18:08:12 +08:00
Status = dict.Status,
CssClass = dict.CssClass,
ListClass = dict.ListClass
2021-08-23 16:57:25 +08:00
})
.Where(f => f.DictCode == dict.DictCode).ExecuteCommand();
}
/// <summary>
/// 批量删除字典数据信息
/// </summary>
/// <param name="dictCodes"></param>
/// <returns></returns>
public int DeleteDictDataByIds(long[] dictCodes)
{
2021-09-27 16:07:55 +08:00
return Delete(dictCodes);
2021-08-23 16:57:25 +08:00
}
/// <summary>
/// 同步修改字典类型
/// </summary>
/// <param name="old_dictType">旧字典类型</param>
/// <param name="new_dictType">新字典类型</param>
/// <returns></returns>
public int UpdateDictDataType(string old_dictType, string new_dictType)
{
//只更新DictType字段根据where条件
2021-09-27 08:06:09 +08:00
return Context.Updateable<SysDictData>()
2021-08-23 16:57:25 +08:00
.SetColumns(t => new SysDictData() { DictType = new_dictType })
.Where(f => f.DictType == old_dictType)
.ExecuteCommand();
}
2022-09-16 08:20:09 +08:00
/// <summary>
/// 根据字典类型查询自定义sql
/// </summary>
/// <param name="dictType"></param>
/// <returns></returns>
public List<SysDictData> SelectDictDataByCustomSql(SysDictType sysDictType)
{
return Context.Ado.SqlQuery<SysDictData>(sysDictType?.CustomSql).ToList();
}
2021-08-23 16:57:25 +08:00
}
}