颐和api

ISqlRepository.cs 4.5KB

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