ISqlSugarRepository.cs 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. // 大名科技(天津)有限公司 版权所有
  2. //
  3. // 此源代码遵循位于源代码树根目录中的 LICENSE 文件的许可证
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动
  6. //
  7. // 任何基于本项目二次开发而产生的一切法律纠纷和责任,均与作者无关
  8. namespace Admin.NET.Core;
  9. public interface ISqlSugarRepository<T> : ISugarRepository, ISimpleClient<T> where T : class, new()
  10. {
  11. /// <summary>
  12. /// 分表批量创建数据
  13. /// </summary>
  14. /// <param name="input">数据</param>
  15. /// <returns></returns>
  16. Task<bool> SplitTableInsertAsync(List<T> input);
  17. /// <summary>
  18. /// 分表创建数据
  19. /// </summary>
  20. /// <param name="input">数据</param>
  21. /// <returns></returns>
  22. Task<bool> SplitTableInsertAsync(T input);
  23. /// <summary>
  24. /// 分表批量删除数据
  25. /// </summary>
  26. /// <param name="input">数据</param>
  27. /// <returns></returns>
  28. Task<bool> SplitTableDeleteableAsync(List<T> input);
  29. /// <summary>
  30. /// 分表删除数据
  31. /// </summary>
  32. /// <param name="input">数据</param>
  33. /// <returns></returns>
  34. Task<bool> SplitTableDeleteableAsync(T input);
  35. /// <summary>
  36. /// 分表批量更新数据
  37. /// </summary>
  38. /// <param name="input">数据</param>
  39. /// <returns></returns>
  40. Task<bool> SplitTableUpdateAsync(List<T> input);
  41. /// <summary>
  42. /// 分表更新数据
  43. /// </summary>
  44. /// <param name="input">数据</param>
  45. /// <returns></returns>
  46. Task<bool> SplitTableUpdateAsync(T input);
  47. /// <summary>
  48. /// 分表判断是否存在
  49. /// </summary>
  50. /// <param name="whereExpression"></param>
  51. /// <returns></returns>
  52. Task<bool> SplitTableIsAnyAsync(Expression<Func<T, bool>> whereExpression);
  53. /// <summary>
  54. /// 分表获取列表
  55. /// </summary>
  56. /// <param name="whereExpression">条件</param>
  57. /// <returns></returns>
  58. Task<List<T>> SplitTableGetListAsync(Expression<Func<T, bool>> whereExpression);
  59. /// <summary>
  60. /// 分表获取列表
  61. /// </summary>
  62. /// <returns></returns>
  63. Task<List<T>> SplitTableGetListAsync();
  64. /// <summary>
  65. /// 分表GetFirstAsyn
  66. /// </summary>
  67. /// <param name="whereExpression"></param>
  68. /// <returns></returns>
  69. Task<T> SplitTableGetFirstAsync(Expression<Func<T, bool>> whereExpression);
  70. /// <summary>
  71. /// 分表获取列表
  72. /// </summary>
  73. /// <param name="whereExpression">条件</param>
  74. /// <param name="tableNames">分表表名</param>
  75. /// <returns></returns>
  76. Task<List<T>> SplitTableGetListAsync(Expression<Func<T, bool>> whereExpression, string[] tableNames);
  77. }