AutoJobService.cs 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. using System;
  2. using System.Linq;
  3. using System.Collections.Generic;
  4. using System.Linq.Expressions;
  5. using System.Threading.Tasks;
  6. using YiSha.Util;
  7. using YiSha.Util.Extension;
  8. using YiSha.Util.Model;
  9. using YiSha.Data.Repository;
  10. using YiSha.Entity.SystemManage;
  11. using YiSha.Model.Param.SystemManage;
  12. using YiSha.Enum;
  13. namespace YiSha.Service.SystemManage
  14. {
  15. public partial class AutoJobService
  16. {
  17. private IRepositoryFactory _baseRepository;
  18. public AutoJobService(IRepositoryFactory baseRepository)
  19. {
  20. _baseRepository = baseRepository;
  21. }
  22. #region 获取数据
  23. public async Task<List<AutoJobEntity>> GetListPartial(AutoJobListParam param)
  24. {
  25. var expression = ListFilterPartial(param);
  26. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression);
  27. return list.ToList();
  28. }
  29. public async Task<List<AutoJobEntity>> GetPageListPartial(AutoJobListParam param, Pagination pagination)
  30. {
  31. var expression = ListFilterPartial(param);
  32. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression, pagination);
  33. return list.ToList();
  34. }
  35. public async Task<AutoJobEntity> GetEntityPartial(int id)
  36. {
  37. return await _baseRepository.BaseRepository(dbConnectType).FindEntity<AutoJobEntity>(id);
  38. }
  39. public bool ExistJobPartial(AutoJobEntity entity)
  40. {
  41. var expression = LinqExtensions.True<AutoJobEntity>();
  42. expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  43. if (entity.Id.IsNullOrZero())
  44. {
  45. expression = expression.And(t => t.JobGroupName == entity.JobGroupName && t.JobName == entity.JobName);
  46. }
  47. else
  48. {
  49. expression = expression.And(t => t.JobGroupName == entity.JobGroupName && t.JobName == entity.JobName && t.Id != entity.Id);
  50. }
  51. return _baseRepository.BaseRepository(dbConnectType).IQueryable(expression).Count() > 0 ? true : false;
  52. }
  53. #endregion
  54. #region 提交数据
  55. public async Task SaveFormPartial(AutoJobEntity entity)
  56. {
  57. if (entity.Id.IsNullOrZero())
  58. {
  59. await entity.Create();
  60. await _baseRepository.BaseRepository(dbConnectType).Insert<AutoJobEntity>(entity);
  61. }
  62. else
  63. {
  64. await entity.Modify();
  65. await _baseRepository.BaseRepository(dbConnectType).Update<AutoJobEntity>(entity);
  66. }
  67. }
  68. #endregion
  69. #region 私有方法
  70. private Expression<Func<AutoJobEntity, bool>> ListFilterPartial(AutoJobListParam param)
  71. {
  72. var expression = LinqExtensions.True<AutoJobEntity>();
  73. expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  74. if (param != null)
  75. {
  76. if (!string.IsNullOrEmpty(param.JobName))
  77. {
  78. expression = expression.And(t => t.JobName.Contains(param.JobName));
  79. }
  80. }
  81. return expression;
  82. }
  83. #endregion
  84. }
  85. }