IMongoDB.cs 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. using MongoDB.Driver;
  2. using MongoDB.Driver.Linq;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Reflection.Metadata;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using Volo.Abp.Domain.Entities;
  11. namespace Business.Core.MongoDBHelper
  12. {
  13. /// <summary>
  14. /// MongoDB接口
  15. /// </summary>
  16. /// <typeparam name="T"></typeparam>
  17. public interface IMongoDB<T> where T : Entity<long>
  18. {
  19. /// <summary>
  20. /// 插入一条数据
  21. /// </summary>
  22. /// <param name="document"></param>
  23. /// <returns></returns>
  24. Task InsertOne(T document);
  25. /// <summary>
  26. /// 插入多条数据
  27. /// </summary>
  28. /// <param name="documents"></param>
  29. /// <returns></returns>
  30. Task InsertMany(List<T> documents);
  31. /// <summary>
  32. /// 更新一条数据
  33. /// </summary>
  34. /// <param name="documents"></param>
  35. /// <param name="id"></param>
  36. /// <returns></returns>
  37. Task<ReplaceOneResult> UpdateOne(T documents,long id);
  38. /// <summary>
  39. /// 获取所有数据
  40. /// </summary>
  41. /// <returns></returns>
  42. Task<List<T>> GetAll();
  43. /// <summary>
  44. /// 根据ID获取数据
  45. /// </summary>
  46. /// <param name="id"></param>
  47. /// <returns></returns>
  48. Task<T> GetOneByID(long id);
  49. /// <summary>
  50. /// 根据条件获取数据
  51. /// </summary>
  52. /// <returns></returns>
  53. Task<List<T>> GetManyByCondition(Expression<Func<T, bool>> filter);
  54. /// <summary>
  55. /// 根据条件获取数据
  56. /// </summary>
  57. /// <returns></returns>
  58. Task<List<T>> GetManyByIds(FilterDefinition<T> filter);
  59. }
  60. }