GalleryManagerModelsService.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. using System;
  2. using System.Linq;
  3. using System.Text;
  4. using System.Data.Common;
  5. using System.Linq.Expressions;
  6. using System.Collections.Generic;
  7. using System.Threading.Tasks;
  8. using YiSha.Util;
  9. using YiSha.Util.Extension;
  10. using YiSha.Util.Model;
  11. using YiSha.Data;
  12. using YiSha.Data.Repository;
  13. using YiSha.Enum;
  14. using System.ComponentModel.DataAnnotations.Schema;
  15. using YiSha.Entity.TK;
  16. using YiSha.Model.Param.TK;
  17. using YiSha.IService.TK;
  18. using YiSha.Web.Code;
  19. using YiSha.Model.Result.TK;
  20. using YiSha.Enum.ZX;
  21. namespace YiSha.Service.TK
  22. {
  23. /// <summary>
  24. /// 创 建:cmzx
  25. /// 日 期:2021-04-20 16:57
  26. /// 描 述:图库管理服务实现类(部分类)
  27. /// </summary>
  28. public partial class GalleryManagerModelsService
  29. {
  30. private IRepositoryFactory _baseRepository;
  31. public GalleryManagerModelsService(IRepositoryFactory baseRepository)
  32. {
  33. _baseRepository = baseRepository;
  34. }
  35. /// <summary>
  36. /// 获取分页数据
  37. /// </summary>
  38. /// <param name="param">请求参数</param>
  39. /// <param name="pagination">分页条件</param>
  40. /// <returns></returns>
  41. public async Task<List<GalleryManagerModelsPageJoinModel>> GetPageListPartial(GalleryManagerModelsListParam param, Pagination pagination)
  42. {
  43. var parameters = new List<DbParameter>();
  44. var sql = SqlPageList(param, pagination, out parameters);
  45. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<GalleryManagerModelsPageJoinModel>(sql, parameters.ToArray());
  46. return list.ToList();
  47. }
  48. /// <summary>
  49. /// 保存数据(由于之前数据库设计不规范,无法实现在新增、修改时保存正确的操作用户信息,每张表的创建时间和创建人id、创建人姓名都不一样,且这些字段是必填项)
  50. /// </summary>
  51. /// <param name="entity">实体参数</param>
  52. /// <returns></returns>
  53. public async Task<int> SaveFormPartial(GalleryManagerModelsEntity entity)
  54. {
  55. OperatorInfo user = await Operator.Instance.Current(entity.Token);
  56. if (entity.Id.IsNullOrZero())
  57. {
  58. entity.createTime = DateTime.Now;
  59. entity.createUserId = user?.UserId;
  60. entity.createUserName = user?.UserName;
  61. return await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  62. }
  63. else
  64. {
  65. return await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  66. }
  67. }
  68. #region 私有方法
  69. /// <summary>
  70. /// 列表条件过滤
  71. /// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
  72. /// </summary>
  73. /// <param name="param"></param>
  74. /// <returns></returns>
  75. private Expression<Func<GalleryManagerModelsEntity, bool>> ListFilterPartial(GalleryManagerModelsListParam param)
  76. {
  77. var expression = LinqExtensions.True<GalleryManagerModelsEntity>();
  78. if (param != null)
  79. {
  80. }
  81. return expression;
  82. }
  83. /// <summary>
  84. /// 获取分页Sql语句
  85. /// </summary>
  86. /// <param name="param"></param>
  87. /// <returns></returns>
  88. private string SqlPageList(GalleryManagerModelsListParam param, Pagination pagination, out List<DbParameter> parameters)
  89. {
  90. parameters = new List<DbParameter>();
  91. var where = new StringBuilder();
  92. where.Append($" 1 = 1 and isDelete = {TkIsDeleteEnum.正常.ParseToInt()} ");
  93. if (param != null)
  94. {
  95. if (!string.IsNullOrEmpty(param.GalleryName))
  96. {
  97. where.Append(" and galleryName like @GalleryName ");
  98. parameters.Add(DbParameterExtension.CreateDbParameter("@GalleryName", $"%{param.GalleryName}%", dbConnectType));
  99. }
  100. //if (param.ViewType != null)
  101. //{
  102. // where.Append(" and ViewType = @ViewType ");
  103. // parameters.Add(DbParameterExtension.CreateDbParameter("@ViewType", param.ViewType.ParseToInt(), dbConnectType));
  104. //}
  105. }
  106. //获取分页数据Sql
  107. var pageSql = $@"select * from galleryManagerModels where {where.ToString()}";
  108. //统计总数据Sql
  109. var totalSql = $@"select count(1) from galleryManagerModels where {where.ToString()}";
  110. pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
  111. return pageSql;
  112. }
  113. #endregion
  114. }
  115. }