颐和api

IRepository.cs 4.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. using MongoDB.Driver;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Linq.Expressions;
  6. using System.Threading.Tasks;
  7. namespace MadRunFabric.Common
  8. {
  9. public interface IRepository<T, TKey> where T : class, IBaseModel<TKey>
  10. {
  11. /// <summary>
  12. /// 获取查询的数量
  13. /// </summary>
  14. /// <param name="where"></param>
  15. /// <returns></returns>e
  16. Task<long> Count(Expression<Func<T, bool>> @where = null);
  17. /// <summary>
  18. /// 根据Key查询第一条 (默认id)
  19. /// </summary>
  20. /// <param name="key"></param>
  21. /// <returns></returns>
  22. Task<T> GetSingle(TKey key);
  23. /// <summary>
  24. /// 根据查询条件查询
  25. /// </summary>
  26. /// <param name="where"></param>
  27. /// <returns></returns>
  28. Task<T> GetSingle(Expression<Func<T, bool>> @where = null);
  29. /// <summary>
  30. /// 查询一条数据 条件 排序
  31. /// </summary>
  32. /// <param name="where"></param>
  33. /// <returns></returns>
  34. Task<T> GetSingle(Expression<Func<T, bool>> @where = null,SortDefinition<T> sort = null);
  35. /// <summary>
  36. /// 根据条件查询
  37. /// </summary>
  38. /// <param name="expression"></param>
  39. /// <returns></returns>
  40. Task<IEnumerable<T>> Get(Expression<Func<T, bool>> @where = null);
  41. /// <summary>
  42. /// 查询数据列表 包含查询条件,显示字段,排序
  43. /// </summary>
  44. /// <param name="filter"></param>
  45. /// <param name="field"></param>
  46. /// <param name="sort"></param>
  47. /// <returns></returns>
  48. Task<IEnumerable<T>> Get(FilterDefinition<T> filter, string[] field = null, SortDefinition<T> sort = null);
  49. /// <summary>
  50. /// 根据分页查询数据列表 包含查询条件,显示字段,排序
  51. /// </summary>
  52. /// <param name="filter"></param>
  53. /// <param name="pageIndex"></param>
  54. /// <param name="pageSize"></param>
  55. /// <param name="sort"></param>
  56. /// <returns></returns>
  57. Task<IEnumerable<T>> GetByPage(FilterDefinition<T> filter, int pageIndex, int pageSize, SortDefinition<T> sort = null);
  58. /// <summary>
  59. /// 查询所有
  60. /// </summary>
  61. /// <returns></returns>
  62. Task<IEnumerable<T>> GetAll();
  63. /// <summary>
  64. /// 添加一項
  65. /// </summary>
  66. /// <param name="entity"></param>
  67. /// <returns></returns>
  68. Task<bool> Add(T entity);
  69. /// <summary>
  70. /// 添加多項 (多条数据务必如此)
  71. /// </summary>
  72. /// <param name="entitys"></param>
  73. /// <returns></returns>
  74. Task<bool> AddRange(List<T> entitys);
  75. /// <summary>
  76. /// 根据key删除
  77. /// </summary>
  78. /// <param name="key"></param>
  79. /// <returns></returns>
  80. Task<bool> Remove(TKey key);
  81. /// <summary>
  82. /// 根据表达式删除
  83. /// </summary>
  84. /// <param name="expression"></param>
  85. /// <returns></returns>
  86. Task<bool> Remove(Expression<Func<T, bool>> @where=null);
  87. /// <summary>
  88. /// 删除所有
  89. /// </summary>
  90. /// <returns></returns>
  91. Task<bool> RemoveAll();
  92. /// <summary>
  93. /// 修改数据
  94. /// </summary>
  95. /// <param name="entity"></param>
  96. /// <returns></returns>
  97. Task<bool> Update(T entity);
  98. /// <summary>
  99. /// 修改数据
  100. /// </summary>
  101. /// <param name="id"></param>
  102. /// <param name="dic">要修改的字段</param>
  103. /// <returns></returns>
  104. Task<bool> Update(string id, Dictionary<object, object> dic);
  105. /// <summary>
  106. /// 修改数据
  107. /// </summary>
  108. /// <param name="entity"></param>
  109. /// <returns></returns>
  110. Task<bool> UpdateOne(T entity);
  111. /// <summary>
  112. /// 批量修改数据
  113. /// </summary>
  114. Task<bool> UpdateManay(T entity, Dictionary<string, string> dic, FilterDefinition<T> filter = null);
  115. /// <summary>
  116. /// 异步根据条件获取总数
  117. /// </summary>
  118. /// <param name="filter">条件</param>
  119. /// <returns></returns>
  120. Task<long> CountAsync(FilterDefinition<T> filter);
  121. /// <summary>
  122. /// 添加一項
  123. /// </summary>
  124. /// <param name="entity"></param>
  125. /// <returns></returns>
  126. Task<string> AddRetID(T entity);
  127. }
  128. }