足力健后端,使用.netcore版本,合并1个项目使用

IRepository.cs 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. using SqlSugar;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq.Expressions;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace System.Common
  8. {
  9. public interface IRepository<T> where T : class
  10. {
  11. /// <summary>
  12. /// 获取数量
  13. /// </summary>
  14. /// <param name="whereExpression"></param>
  15. /// <returns></returns>
  16. Task<int> GetCount(Expression<Func<T, bool>> whereExpression = null);
  17. /// <summary>
  18. /// 获取所有
  19. /// </summary>
  20. /// <returns></returns>
  21. Task<List<T>> GetList();
  22. Task<List<T>> GetListALL(Expression<Func<T, bool>> whereExpression);
  23. Task<List<T>> GetListALL(List<IConditionalModel> conModels, string orderby);
  24. Task<List<T>> GetListALL(Expression<Func<T, bool>> whereExpression, Expression<Func<T, object>> orderExpression, OrderByType ordertype = OrderByType.Asc);
  25. /// <summary>
  26. /// 分页获取所有
  27. /// </summary>
  28. /// <returns></returns>
  29. Task<PageData<T>> GetListByPage(List<IConditionalModel> conModels, MyPageModel pagemodel);
  30. Task<PageData<T>> GetListByPage(List<IConditionalModel> conModels, MyPageModel pagemodel, string orderby);
  31. Task<PageData<T>> GetListByPage(Expression<Func<T, bool>> whereExpression, MyPageModel pagemodel);
  32. Task<PageData<T>> GetListByPage(Expression<Func<T, bool>> whereExpression, MyPageModel pagemodel, string orderby);
  33. Task<T> GetSingle(Expression<Func<T, bool>> whereExpression);
  34. Task<T> GetFirst(Expression<Func<T, bool>> whereExpression, Expression<Func<T, object>> expression = null, OrderByType type = OrderByType.Asc);
  35. /// <summary>
  36. /// 添加
  37. /// </summary>
  38. Task<int> Add(T obj);
  39. /// <summary>
  40. /// 插入并返回实体
  41. /// </summary>
  42. /// <param name="obj"></param>
  43. /// <returns></returns>
  44. Task<T> AddAndUpdate(T obj,Expression<Func<T, object>> UpdateColumns= null);
  45. /// <summary>
  46. /// 插入并返回实体
  47. /// </summary>
  48. /// <param name="obj"></param>
  49. /// <returns></returns>
  50. Task<T> AddAndUpdateList(List<T> obj,Expression<Func<T, object>> UpdateColumns= null);
  51. /// <summary>
  52. /// 插入并返回影响行数
  53. /// </summary>
  54. /// <param name="obj"></param>
  55. /// <returns></returns>
  56. Task<bool> AddReturnCount(T obj);
  57. /// <summary>
  58. /// 添加排除某列
  59. /// </summary>
  60. /// <param name="obj"></param>
  61. /// <returns></returns>
  62. Task<int> AddIgnore(T obj, Expression<Func<T, object>> IgnoreColumns);
  63. /// <summary>
  64. /// 强势插入,插入自增值
  65. /// </summary>
  66. /// <param name="obj"></param>
  67. /// <param name="isStrong">是否强势</param>
  68. /// <returns></returns>
  69. Task<int> AddStrong(T obj, bool isStrong = false);
  70. /// <summary>
  71. /// 批量添加
  72. /// </summary>
  73. /// <param name="objlist"></param>
  74. /// <returns></returns>
  75. Task<bool> AddMany(List<T> objlist);
  76. /// <summary>
  77. /// 根据主键删除
  78. /// </summary>
  79. /// <param name="id"></param>
  80. /// <returns></returns>
  81. Task<bool> Delete(Expression<Func<T, bool>> whereExpression);
  82. /// <summary>
  83. /// 更新
  84. /// </summary>
  85. /// <param name="id"></param>
  86. /// <returns></returns>
  87. Task<bool> Update(T obj);
  88. /// <summary>
  89. /// 条件更新
  90. /// </summary>
  91. /// <param name="id"></param>
  92. /// <returns></returns>
  93. Task<bool> Update(Expression<Func<T, T>> UpdateColumnsExpression, Expression<Func<T, bool>> whereExpression);
  94. /// <summary>
  95. /// 批量更新
  96. /// </summary>
  97. /// <param name="obj"></param>
  98. /// <returns></returns>
  99. Task<bool> UpdateList(List<T> obj);
  100. /// <summary>
  101. /// 批量指定字段更新
  102. /// </summary>
  103. /// <param name="objColumns">model => new { model.Name }</param>
  104. /// <returns></returns>
  105. Task<bool> UpdateListToColumns(List<T> obj, Expression<Func<T, object>> objColumns);
  106. Task<Data.DataTable> GetTableSugar(string sql, SugarParameter[] sugarParameter = null);
  107. Task<int> ExecuteCommandSugar(string sql, SugarParameter[] sugarParameter = null);
  108. }
  109. }