ISqlSugarRepository.cs 2.7 KB

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