123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- using System;
- using System.Linq;
- using System.Collections.Generic;
- using System.Threading.Tasks;
- using YiSha.Util;
- using YiSha.Util.Extension;
- using YiSha.Util.Model;
- using YiSha.Data.Repository;
- using YiSha.Entity.SystemManage;
- using YiSha.Model.Param.SystemManage;
- using System.Linq.Expressions;
- using YiSha.Enum;
- namespace YiSha.Service.SystemManage
- {
- public partial class DataDictService
- {
- private IRepositoryFactory _baseRepository;
- public DataDictService(IRepositoryFactory baseRepository)
- {
- _baseRepository = baseRepository;
- }
- #region 获取数据
- public async Task<List<DataDictEntity>> GetListPartial(DataDictListParam param)
- {
- var expression = ListFilterPartial(param);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression);
- return list.ToList();
- }
- public async Task<List<DataDictEntity>> GetPageListPartial(DataDictListParam param, Pagination pagination)
- {
- var expression = ListFilterPartial(param);
- var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression, pagination);
- return list.ToList();
- }
- public async Task<DataDictEntity> GetEntityPartial(int id)
- {
- return await _baseRepository.BaseRepository(dbConnectType).FindEntity<DataDictEntity>(id);
- }
- public async Task<int> GetMaxSortPartial()
- {
- object result = await _baseRepository.BaseRepository(dbConnectType).FindObject("SELECT MAX(DictSort) FROM SysDataDict");
- int sort = result.ParseToInt();
- sort++;
- return sort;
- }
- public bool ExistDictTypePartial(DataDictEntity entity)
- {
- var expression = LinqExtensions.True<DataDictEntity>();
- expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
- if (entity.Id.IsNullOrZero())
- {
- expression = expression.And(t => t.DictType == entity.DictType);
- }
- else
- {
- expression = expression.And(t => t.DictType == entity.DictType && t.Id != entity.Id);
- }
- return _baseRepository.BaseRepository(dbConnectType).IQueryable(expression).Count() > 0 ? true : false;
- }
- /// <summary>
- /// 是否存在字典值
- /// </summary>
- /// <param name="id"></param>
- /// <returns></returns>
- public bool ExistDictDetailPartial(string dictType)
- {
- var expression = LinqExtensions.True<DataDictDetailEntity>();
- expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
- expression = expression.And(t => t.DictType == dictType);
- return _baseRepository.BaseRepository(dbConnectType).IQueryable(expression).Count() > 0 ? true : false;
- }
- #endregion
- #region 提交数据
- public async Task SaveFormPartial(DataDictEntity entity)
- {
- var db = await _baseRepository.BaseRepository(dbConnectType).BeginTrans();
- try
- {
- if (!entity.Id.IsNullOrZero())
- {
- var dbEntity = await db.FindEntity<DataDictEntity>(entity.Id);
- if (dbEntity.DictType != entity.DictType)
- {
- // 更新子表的DictType,因为2个表用DictType进行关联
- IEnumerable<DataDictDetailEntity> detailList = await db.FindList<DataDictDetailEntity>(p => p.DictType == dbEntity.DictType);
- foreach (DataDictDetailEntity detailEntity in detailList)
- {
- detailEntity.DictType = entity.DictType;
- await detailEntity.Modify();
- }
- }
- dbEntity.DictType = entity.DictType;
- dbEntity.Remark = entity.Remark;
- dbEntity.DictSort = entity.DictSort;
- await dbEntity.Modify();
- await db.Update<DataDictEntity>(dbEntity);
- }
- else
- {
- await entity.Create();
- await db.Insert<DataDictEntity>(entity);
- }
- await db.CommitTrans();
- }
- catch
- {
- await db.RollbackTrans();
- throw;
- }
- }
- #endregion
- #region 私有方法
- private Expression<Func<DataDictEntity, bool>> ListFilterPartial(DataDictListParam param)
- {
- var expression = LinqExtensions.True<DataDictEntity>();
- expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
- if (param != null)
- {
- if (!param.DictType.IsEmpty())
- {
- expression = expression.And(t => t.DictType.Contains(param.DictType));
- }
- if (!param.Remark.IsEmpty())
- {
- expression = expression.And(t => t.Remark.Contains(param.Remark));
- }
- }
- return expression;
- }
- #endregion
- }
- }
|