LabelModelsService.cs 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  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.ZX;
  16. using YiSha.Model.Param.ZX;
  17. using YiSha.IService.ZX;
  18. using YiSha.Model.Result.ZX;
  19. using YiSha.Web.Code;
  20. namespace YiSha.Service.ZX
  21. {
  22. /// <summary>
  23. /// 创 建:cmzx
  24. /// 日 期:2021-04-15 09:36
  25. /// 描 述:资讯专家标签服务实现类(部分类)
  26. /// </summary>
  27. public partial class LabelModelsService
  28. {
  29. private IRepositoryFactory _baseRepository;
  30. public LabelModelsService(IRepositoryFactory baseRepository)
  31. {
  32. _baseRepository = baseRepository;
  33. }
  34. /// <summary>
  35. /// 获取分页数据
  36. /// </summary>
  37. /// <param name="param">请求参数</param>
  38. /// <param name="pagination">分页条件</param>
  39. /// <returns></returns>
  40. public async Task<List<LabelModelsPageJoinModel>> GetPageListPartial(LabelModelsListParam param, Pagination pagination)
  41. {
  42. var parameters = new List<DbParameter>();
  43. var sql = SqlPageList(param, pagination, out parameters);
  44. var list = await _baseRepository.BaseRepository(dbConnectType).FindList<LabelModelsPageJoinModel>(sql, parameters.ToArray());
  45. return list.ToList();
  46. }
  47. /// <summary>
  48. /// 保存数据(由于之前数据库设计不规范,无法实现在新增、修改时保存正确的操作用户信息,每张表的创建时间和创建人id、创建人姓名都不一样,且这些字段是必填项)
  49. /// </summary>
  50. /// <param name="entity">实体参数</param>
  51. /// <returns></returns>
  52. public async Task<int> SaveFormPartial(LabelModelsEntity entity)
  53. {
  54. OperatorInfo user = await Operator.Instance.Current(entity.Token);
  55. if (entity.Id.IsNullOrZero())
  56. {
  57. entity.createTime = DateTime.Now;
  58. entity.createUserId = user?.UserId;
  59. entity.createUserName = user?.UserName;
  60. return await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  61. }
  62. else
  63. {
  64. return await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  65. }
  66. }
  67. #region 私有方法
  68. /// <summary>
  69. /// 列表条件过滤
  70. /// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
  71. /// </summary>
  72. /// <param name="param"></param>
  73. /// <returns></returns>
  74. private Expression<Func<LabelModelsEntity, bool>> ListFilterPartial(LabelModelsListParam param)
  75. {
  76. var expression = LinqExtensions.True<LabelModelsEntity>();
  77. if (param != null)
  78. {
  79. if (!string.IsNullOrEmpty(param.LabelName))
  80. expression = expression.And(t => t.labelName.Equals(param.LabelName));
  81. if (!param.MenuId.IsNullOrZero())
  82. expression = expression.And(t => t.menuId == param.MenuId);
  83. }
  84. return expression;
  85. }
  86. /// <summary>
  87. /// 获取分页Sql语句
  88. /// </summary>
  89. /// <param name="param"></param>
  90. /// <returns></returns>
  91. private string SqlPageList(LabelModelsListParam param, Pagination pagination, out List<DbParameter> parameters)
  92. {
  93. parameters = new List<DbParameter>();
  94. var where = new StringBuilder();
  95. where.Append(" 1 = 1 ");
  96. if (param != null)
  97. {
  98. if (!string.IsNullOrEmpty(param.LabelName))
  99. {
  100. where.Append(" and lm.LabelName like @LabelName ");
  101. parameters.Add(DbParameterExtension.CreateDbParameter("@LabelName", $"%{param.LabelName}%", dbConnectType));
  102. }
  103. if (!string.IsNullOrEmpty(param.MenuName))
  104. {
  105. where.Append(" and mmm.menuName like @MenuName ");
  106. parameters.Add(DbParameterExtension.CreateDbParameter("@MenuName", $"%{param.MenuName}%", dbConnectType));
  107. }
  108. }
  109. //获取分页数据Sql
  110. var pageSql = $@"select lm.*,mmm.menuName
  111. from LabelModels lm
  112. left join menuManagerModels mmm on lm.menuId = mmm.id
  113. where {where.ToString()}";
  114. //统计总数据Sql
  115. var totalSql = $@"select count(1)
  116. from LabelModels lm
  117. left join menuManagerModels mmm on lm.menuId = mmm.id
  118. where {where.ToString()}";
  119. pageSql = SqlserverHelper.GetInstance.SqlPageList(pageSql, totalSql, pagination);
  120. return pageSql;
  121. }
  122. #endregion
  123. }
  124. }