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

IRepository.cs 3.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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);
  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<bool> AddReturnCount(T obj);
  45. /// <summary>
  46. /// 添加排除某列
  47. /// </summary>
  48. /// <param name="obj"></param>
  49. /// <returns></returns>
  50. Task<int> AddIgnore(T obj, Expression<Func<T, object>> IgnoreColumns);
  51. /// <summary>
  52. /// 强势插入,插入自增值
  53. /// </summary>
  54. /// <param name="obj"></param>
  55. /// <param name="isStrong">是否强势</param>
  56. /// <returns></returns>
  57. Task<int> AddStrong(T obj, bool isStrong = false);
  58. /// <summary>
  59. /// 批量添加
  60. /// </summary>
  61. /// <param name="objlist"></param>
  62. /// <returns></returns>
  63. Task<bool> AddMany(List<T> objlist);
  64. /// <summary>
  65. /// 根据主键删除
  66. /// </summary>
  67. /// <param name="id"></param>
  68. /// <returns></returns>
  69. Task<bool> Delete(Expression<Func<T, bool>> whereExpression);
  70. /// <summary>
  71. /// 更新
  72. /// </summary>
  73. /// <param name="id"></param>
  74. /// <returns></returns>
  75. Task<bool> Update(T obj);
  76. /// <summary>
  77. /// 条件更新
  78. /// </summary>
  79. /// <param name="id"></param>
  80. /// <returns></returns>
  81. Task<bool> Update(Expression<Func<T, T>> UpdateColumnsExpression, Expression<Func<T, bool>> whereExpression);
  82. /// <summary>
  83. /// 批量更新
  84. /// </summary>
  85. /// <param name="obj"></param>
  86. /// <returns></returns>
  87. Task<bool> UpdateList(List<T> obj);
  88. /// <summary>
  89. /// 批量指定字段更新
  90. /// </summary>
  91. /// <param name="objColumns">model => new { model.Name }</param>
  92. /// <returns></returns>
  93. Task<bool> UpdateListToColumns(List<T> obj, Expression<Func<T, object>> objColumns);
  94. Task<Data.DataTable> GetTableSugar(string sql, SugarParameter[] sugarParameter = null);
  95. Task<int> ExecuteCommandSugar(string sql, SugarParameter[] sugarParameter = null);
  96. }
  97. }