RoleService.cs 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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.SystemManage;
  16. using YiSha.Model.Param.SystemManage;
  17. using YiSha.IService.SystemManage;
  18. namespace YiSha.Service.SystemManage
  19. {
  20. /// <summary>
  21. /// 创 建:admin
  22. /// 日 期:2021-04-14 14:41
  23. /// 描 述:角色服务实现类
  24. /// </summary>
  25. public partial class RoleService : IRoleService
  26. {
  27. private DBConnectTypeEnum dbConnectType = DBConnectTypeEnum.SystemDB;
  28. #region 获取数据
  29. /// <summary>
  30. /// 获取列表数据
  31. /// </summary>
  32. /// <param name="param">请求参数</param>
  33. /// <returns></returns>
  34. public async Task<List<RoleEntity>> GetList(RoleListParam param)
  35. {
  36. var expression = ListFilterPartial(param);
  37. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression);
  38. return list.ToList();
  39. }
  40. /// <summary>
  41. /// 获取分页数据
  42. /// </summary>
  43. /// <param name="param">请求参数</param>
  44. /// <param name="pagination">分页条件</param>
  45. /// <returns></returns>
  46. public async Task<List<RoleEntity>> GetPageList(RoleListParam param, Pagination pagination)
  47. {
  48. var expression = ListFilterPartial(param);
  49. var list = await _baseRepository.BaseRepository(dbConnectType).FindList(expression, pagination);
  50. return list.ToList();
  51. }
  52. /// <summary>
  53. /// 获取指定列数据
  54. /// </summary>
  55. /// <param name="column">表字段列</param>
  56. /// <param name="where">条件</param>
  57. /// <param name="parameters">条件参数</param>
  58. /// <param name="sort">排序列</param>
  59. /// <param name="sortType">排序类型</param>
  60. /// <returns></returns>
  61. public async Task<List<RoleEntity>> GetListColumn(string column, string where, List<DbParameter> parameters, string groupBy = "", string sort = "basecreatetime", string sortType = "desc")
  62. {
  63. if (string.IsNullOrEmpty(column) || string.IsNullOrEmpty(where))
  64. return new List<RoleEntity>();
  65. if (!string.IsNullOrEmpty(groupBy))
  66. groupBy = $" group by {groupBy} ";
  67. string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
  68. string selectSql = $"select {column} from {tableName} where baseisdelete = @baseisdelete and {where} {groupBy} order by {sort} {sortType}";
  69. parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.No, dbConnectType));
  70. var result = await _baseRepository.BaseRepository(dbConnectType).FindList<RoleEntity>(selectSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
  71. return result.ToList();
  72. }
  73. /// <summary>
  74. /// 根据主键Id获取数据
  75. /// </summary>
  76. /// <param name="id">主键id</param>
  77. /// <returns></returns>
  78. public async Task<RoleEntity> GetEntity(int id)
  79. {
  80. return await _baseRepository.BaseRepository(dbConnectType).FindEntity<RoleEntity>(id);
  81. }
  82. #endregion
  83. #region 提交数据
  84. /// <summary>
  85. /// 保存数据
  86. /// </summary>
  87. /// <param name="entity">实体参数</param>
  88. /// <returns></returns>
  89. public async Task SaveForm(RoleEntity entity)
  90. {
  91. if (entity.Id.IsNullOrZero())
  92. {
  93. await entity.Create();
  94. await _baseRepository.BaseRepository(dbConnectType).Insert(entity);
  95. }
  96. else
  97. {
  98. await entity.Modify();
  99. await _baseRepository.BaseRepository(dbConnectType).Update(entity);
  100. }
  101. }
  102. /// <summary>
  103. /// 保存多条数据
  104. /// </summary>
  105. /// <param name="list">数据列表</param>
  106. /// <returns></returns>
  107. public async Task<int> InsertMany(List<RoleEntity> list)
  108. {
  109. return await _baseRepository.BaseRepository(dbConnectType).Insert(list);
  110. }
  111. /// <summary>
  112. /// 根据主键Id删除数据
  113. /// </summary>
  114. /// <param name="ids">主键Id</param>
  115. /// <param name="del">是否真删除 true真删除 false软删除 默认false</param>
  116. /// <returns></returns>
  117. public async Task<int> DeleteFormById(string ids, bool del = false)
  118. {
  119. if (string.IsNullOrWhiteSpace(ids) || !ids.Split(", ").Any())
  120. {
  121. return await Task.FromResult(-1);
  122. }
  123. ids = $"{ string.Join(",", ids.Split(","))}";
  124. string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
  125. string deleteSql = $"update {tableName} set baseisdelete = @baseisdelete where FIND_IN_SET (id,@id)";
  126. if (del)
  127. {
  128. deleteSql = $"delete from {tableName} where FIND_IN_SET (id,@id)";
  129. }
  130. List<DbParameter> parameters = new List<DbParameter>();
  131. parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.Yes, dbConnectType));
  132. parameters.Add(DbParameterExtension.CreateDbParameter("@id", ids, dbConnectType));
  133. return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(deleteSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
  134. }
  135. /// <summary>
  136. /// 根据条件删除数据
  137. /// </summary>
  138. /// <param name="where">where条件</param>
  139. /// <param name="parameters">参数</param>
  140. /// <param name="del">是否真删除 true真删除 false软删除 默认false</param>
  141. /// <returns></returns>
  142. public async Task<int> DeleteFormByWhere(string where, List<DbParameter> parameters, bool del = false)
  143. {
  144. if (string.IsNullOrWhiteSpace(where))
  145. {
  146. return await Task.FromResult(-1);
  147. }
  148. string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
  149. string deleteSql = $"update {tableName} set baseisdelete = @baseisdelete where {where}";
  150. if (del)
  151. {
  152. deleteSql = $"delete from {tableName} where {where}";
  153. }
  154. parameters.Add(DbParameterExtension.CreateDbParameter("@baseisdelete", (int)IsDeleteEnum.Yes, dbConnectType));
  155. return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(deleteSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
  156. }
  157. /// <summary>
  158. /// 修改多条数据
  159. /// </summary>
  160. /// <param name="list">数据列表</param>
  161. /// <returns></returns>
  162. public async Task<int> UpdateMany(List<RoleEntity> list)
  163. {
  164. return await _baseRepository.BaseRepository(dbConnectType).Update(list);
  165. }
  166. /// <summary>
  167. /// 根据条件修改数据
  168. /// </summary>
  169. /// <param name="setField">修改字段</param>
  170. /// <param name="where">where条件</param>
  171. /// <param name="parameters">参数</param>
  172. /// <returns></returns>
  173. public async Task<int> UpdateFormByWhere(string setField, string where, List<DbParameter> parameters)
  174. {
  175. if (string.IsNullOrWhiteSpace(setField) || string.IsNullOrWhiteSpace(where))
  176. {
  177. return await Task.FromResult(-1);
  178. }
  179. string tableName = typeof(RoleEntity).GetAttributeValue((TableAttribute ta) => ta.Name);
  180. string updateSql = $"update {tableName} set {setField} where {where}";
  181. return await _baseRepository.BaseRepository(dbConnectType).ExecuteBySql(updateSql, DbParameterExtension.ToDbParameter(parameters.ToArray()));
  182. }
  183. #endregion
  184. #region 私有方法
  185. ///// <summary>
  186. ///// 列表条件过滤
  187. ///// 建议该方法放在Partial部分类中,因为代码生成时当前类会被覆盖(该方法在生成时将会被注释)
  188. ///// </summary>
  189. ///// <param name="param"></param>
  190. ///// <returns></returns>
  191. //private Expression<Func<RoleEntity, bool>> ListFilter(RoleListParam param)
  192. //{
  193. // var expression = LinqExtensions.True<RoleEntity>();
  194. // expression = expression.And(t => t.BaseIsDelete == (int)IsDeleteEnum.No);
  195. // if (param != null)
  196. // {
  197. // }
  198. // return expression;
  199. //}
  200. #endregion
  201. }
  202. }