You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

252 lines
9.3KB

  1. using System.Data;
  2. using System.Data.Common;
  3. using System.Linq.Expressions;
  4. namespace HealthMonitor.Core.Dal
  5. {
  6. /// <summary>
  7. /// 数据接入层接口
  8. /// </summary>
  9. public interface IDataAccessor : IWithDataSchema, IDisposable
  10. {
  11. /// <summary>
  12. /// 是否已关闭
  13. /// </summary>
  14. /// <returns></returns>
  15. bool IsClose();
  16. /// <summary>
  17. /// 关闭连接
  18. /// </summary>
  19. void Close();
  20. /// <summary>
  21. /// 获取第一个符合条件的实体,或返回null
  22. /// </summary>
  23. /// <param name="expression"></param>
  24. /// <returns></returns>
  25. T GetFirstOrDefault<T>(Expression<Func<T, bool>> expression) where T : class;
  26. /// <summary>
  27. /// 根据主键值来查询某条记录,单主键的表可直接输入主键,多主键的表注意主键次序
  28. /// </summary>
  29. /// <typeparam name="T">实体类型</typeparam>
  30. /// <param name="values">主键值</param>
  31. /// <returns>返回主键值为传入值的实体</returns>
  32. T GetByID<T>(params object[] values) where T : class;
  33. /// <summary>
  34. /// 根据主键值来查询某条记录,单主键的表可直接输入主键,多主键的表注意主键次序
  35. /// </summary>
  36. /// <typeparam name="T">实体类型</typeparam>
  37. /// <param name="values">主键值</param>
  38. /// <returns>返回主键值为传入值的实体</returns>
  39. Task<T> GetByIDAsync<T>(params object[] values) where T : class;
  40. /// <summary>
  41. /// 获取某个表的所有数据
  42. /// </summary>
  43. /// <typeparam name="T"></typeparam>
  44. /// <returns></returns>
  45. IQueryable<T> GetAll<T>() where T : class;
  46. /// <summary>
  47. /// 根据表达式进行查询返回结果
  48. /// </summary>
  49. /// <typeparam name="T">查询的类</typeparam>
  50. /// <param name="expression">查询表达式</param>
  51. /// <returns></returns>
  52. IQueryable<T> GetMany<T>(Expression<Func<T, bool>> expression) where T : class;
  53. /// <summary>
  54. /// 根据某个字段的值进行排序
  55. /// </summary>
  56. /// <typeparam name="T">排序后获得的集合的类型</typeparam>
  57. /// <typeparam name="TKey">排序字段的类型</typeparam>
  58. /// <param name="orderExpression">字段表达式 如:basicInfo下根据caseID排序(s=>s.caseID)</param>
  59. /// <param name="isASC">是否升序</param>
  60. /// <returns></returns>
  61. IEnumerable<T> Order<T, TKey>(Func<T, TKey> orderExpression, bool isASC = false) where T : class;
  62. /// <summary>
  63. /// 在数据库中进行分页查询
  64. /// </summary>
  65. /// <typeparam name="T">查询的类</typeparam>
  66. /// <typeparam name="Tkey">查询类的主键类型</typeparam>
  67. /// <param name="pageSize">每页条数</param>
  68. /// <param name="pageIdx">当前页</param>
  69. /// <param name="expression">查询表达式</param>
  70. /// <param name="orderExpression"></param>
  71. /// <returns></returns>
  72. List<T> GetPageList<T, Tkey>(int pageSize, int pageIdx, Expression<Func<T, bool>> expression, Func<T, Tkey> orderExpression) where T : class;
  73. /// <summary>
  74. /// 在数据库中进行分页查询
  75. /// </summary>
  76. /// <typeparam name="T">查询的类</typeparam>
  77. /// <typeparam name="Tkey">查询类的主键类型</typeparam>
  78. /// <param name="pageSize">页大小</param>
  79. /// <param name="pageIdx">页下标</param>
  80. /// <param name="expression">查询表达式</param>
  81. /// <param name="orderExpression">排序表达式</param>
  82. /// <returns>分页查询结果</returns>
  83. Task<List<T>> GetPageListAsync<T, Tkey>(int pageSize, int pageIdx, Expression<Func<T, bool>> expression, Func<T, Tkey> orderExpression) where T : class;
  84. /// <summary>
  85. /// 获取条目数
  86. /// </summary>
  87. /// <typeparam name="T">查询的类</typeparam>
  88. /// <param name="expression">查询表达式</param>
  89. /// <returns>条目数</returns>
  90. int GetCount<T>(Expression<Func<T, bool>> expression) where T : class;
  91. /// <summary>
  92. /// 获取条目数
  93. /// </summary>
  94. /// <typeparam name="T">查询的类</typeparam>
  95. /// <param name="expression">查询表达式</param>
  96. /// <returns>条目数</returns>
  97. Task<int> GetCountAsync<T>(Expression<Func<T, bool>> expression) where T : class;
  98. /// <summary>
  99. /// 插入数据,保存并更新其自增键
  100. /// </summary>
  101. /// <typeparam name="T"></typeparam>
  102. /// <param name="model"></param>
  103. /// <returns></returns>
  104. T AddWithIdentity<T>(T model) where T : class;
  105. /// <summary>
  106. /// 插入数据,保存并更新其自增键
  107. /// </summary>
  108. /// <typeparam name="T"></typeparam>
  109. /// <param name="model"></param>
  110. /// <returns></returns>
  111. Task<T> AddWithIdentityAsync<T>(T model) where T : class;
  112. /// <summary>
  113. /// 向上下文增加记录,但不保存,需要手动调用Save
  114. /// </summary>
  115. /// <typeparam name="T"></typeparam>
  116. /// <param name="model"></param>
  117. /// <returns></returns>
  118. void Add<T>(T model) where T : class;
  119. /// <summary>
  120. /// 向上下文增加记录,但不保存,需要手动调用Save
  121. /// </summary>
  122. /// <param name="model"></param>
  123. /// <returns></returns>
  124. void Add(object model);
  125. /// <summary>
  126. /// 批量插入实体
  127. /// </summary>
  128. /// <param name="models"></param>
  129. void AddRange(IEnumerable<object> models);
  130. /// <summary>
  131. /// 按主键标记实体删除
  132. /// </summary>
  133. /// <typeparam name="T"></typeparam>
  134. /// <param name="model"></param>
  135. /// <returns></returns>
  136. void Delete<T>(T model) where T : class;
  137. /// <summary>
  138. /// 按主键标记实体删除
  139. /// </summary>
  140. /// <param name="model"></param>
  141. /// <returns></returns>
  142. void Delete(object model);
  143. /// <summary>
  144. ///批量删除实体
  145. /// </summary>
  146. /// <param name="models"></param>
  147. void DeleteRanage(IEnumerable<object> models);
  148. /// <summary>
  149. /// 更新操作
  150. /// </summary>
  151. /// <typeparam name="T"></typeparam>
  152. /// <param name="model"></param>
  153. /// <returns></returns>
  154. void Update<T>(T model) where T : class;
  155. /// <summary>
  156. /// 根据主键更新指定字段,使用时需要注意EFCore的仓储机制可能会使数据库和缓存仓的数据不一致。
  157. /// </summary>
  158. /// <typeparam name="T">映射类</typeparam>
  159. /// <param name="model">更新的实体</param>
  160. /// <param name="property">要更新的属性, VisualStudio在这里有Bug, 不能智能显示类型属性, 但不影响使用</param>
  161. /// <returns></returns>
  162. void Update<T>(T model, Expression<Func<T, object>> property) where T : class;
  163. /// <summary>
  164. /// 更新操作
  165. /// </summary>
  166. /// <param name="model"></param>
  167. /// <returns></returns>
  168. void Update(object model);
  169. /// <summary>
  170. /// 批量更新实体
  171. /// </summary>
  172. /// <param name="models"></param>
  173. void UpdateRanage(IEnumerable<object> models);
  174. /// <summary>
  175. /// 执行存储过程,返回存储过程中返回的数据表
  176. /// </summary>
  177. /// <param name="procName">存储过程名</param>
  178. /// <param name="parameters">参数</param>
  179. /// <returns>返回的数据表集合</returns>
  180. List<DataTable> CallProcedure(string procName, params DbParameter[] parameters);
  181. /// <summary>
  182. /// 执行存储过程,返回存储过程中返回的数据表
  183. /// </summary>
  184. /// <param name="procName">存储过程名</param>
  185. /// <param name="parameters">参数</param>
  186. /// <returns>返回的数据表集合</returns>
  187. Task<List<DataTable>> CallProcedureAsync(string procName, params DbParameter[] parameters);
  188. /// <summary>
  189. /// 提交对数据进行的处理,如无处理返回-1
  190. /// </summary>
  191. /// <returns></returns>
  192. int Save();
  193. /// <summary>
  194. /// 提交对数据进行的处理,如无处理返回-1
  195. /// </summary>
  196. /// <returns></returns>
  197. Task<int> SaveAsync();
  198. ///// <summary>
  199. ///// 异步获取一个事务对象
  200. ///// </summary>
  201. ///// <returns></returns>
  202. //Task<IDbContextTransaction> BeginTransactionAsync();
  203. ///// <summary>
  204. ///// 获取一个事务对象
  205. ///// </summary>
  206. ///// <returns></returns>
  207. //IDbContextTransaction BeginTransaction();
  208. /// <summary>
  209. /// 不跟踪实体状态(针对DbContext所用)
  210. /// </summary>
  211. /// <param name="models"></param>
  212. void UntrackEntities(IEnumerable<object> models);
  213. /// <summary>
  214. /// 不跟踪实体状态(针对DbContext所用)
  215. /// </summary>
  216. /// <param name="models"></param>
  217. void UntrackEntities(object model);
  218. }
  219. }