颐和api

Sys_BuildingRepository.cs 4.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. using ConfigurationApi.IRepositories;
  2. using MadRunFabric.Common;
  3. using MadRunFabric.Common.Options;
  4. using Microsoft.Extensions.Logging;
  5. using Microsoft.Extensions.Options;
  6. using MadRunFabric.Model;
  7. using MongoDB.Driver;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Text;
  11. using System.Linq;
  12. namespace ConfigurationApi.Repositories
  13. {
  14. public class Sys_BuildingRepository : BaseRepository<Sys_Building, string>, ISys_BuildingRepository
  15. {
  16. protected readonly ILogger<BaseRepository<Sys_Building, string>> _logger;
  17. protected readonly IMongoCollection<Pro_Project_Info> _collection_pro_project_info;
  18. public Sys_BuildingRepository(IOptions<MongodbOptions> settings, ILogger<BaseRepository<Sys_Building, string>> logger) : base(settings, logger)
  19. {
  20. _collection_pro_project_info = _context.GetCollection<Pro_Project_Info>();//获取集合
  21. _logger = logger;
  22. }
  23. #region 楼
  24. /// <summary>
  25. /// 获取楼层列表 分页 - Linq 关联查询
  26. /// </summary>
  27. /// <param name="keyword"></param>
  28. /// <param name="projectid"></param>
  29. /// <param name="pageIndex"></param>
  30. /// <param name="pageSize"></param>
  31. /// <param name="recordCount"></param>
  32. /// <returns></returns>
  33. public IEnumerable<object> GetBuildListsByPage(string keyword, string projectid, UserAccountInfoModel userinfo, int pageIndex, int pageSize, out int recordCount)
  34. {
  35. //关联查询
  36. var query =
  37. from build in _collection.AsQueryable()
  38. join proje in _collection_pro_project_info.AsQueryable() on build.projectid equals proje.id into projeDefa
  39. where build.isdelete == 0
  40. orderby build.sortnum ascending, build.createtime descending
  41. select new
  42. {
  43. id = build.id,
  44. buildname = build.buildname,
  45. projectid = build.projectid,
  46. projectname = projeDefa != null&& projeDefa.Count()>0 ? projeDefa.First().project_name : null,
  47. sortnum = build.sortnum,
  48. remark = build.remark,
  49. isdelete = build.isdelete,
  50. createtby = build.createtby,
  51. createtime = build.createtime,
  52. };
  53. #region 查询条件
  54. if (!string.IsNullOrEmpty(keyword))
  55. query = query.Where(it => it.buildname.Contains(keyword)); // || it.projectname.Contains(keyword)
  56. if (!string.IsNullOrEmpty(projectid))
  57. query = query.Where(it => it.projectid == projectid);
  58. if (userinfo.isallproject == 0)
  59. query = query.Where(it => userinfo.projectlist.Contains(it.projectid));
  60. #endregion
  61. recordCount = query.Count();
  62. var list = query.Skip((pageIndex - 1) * pageSize).Take(pageSize);
  63. return list;
  64. }
  65. /// <summary>
  66. /// 获取楼详情 - Linq 关联查询详情
  67. /// </summary>
  68. /// <param name="id"></param>
  69. /// <returns></returns>
  70. public object GetBuildDetails(string id)
  71. {
  72. //关联查询
  73. var query =
  74. from build in _collection.AsQueryable()
  75. join proje in _collection_pro_project_info.AsQueryable() on build.projectid equals proje.id into projeDefa
  76. where build.isdelete == 0 && build.id == id
  77. orderby build.createtime
  78. select new
  79. {
  80. id = build.id,
  81. buildname = build.buildname,
  82. projectid = build.projectid,
  83. projectname = projeDefa != null && projeDefa.Count() > 0 ? projeDefa.First().project_name : null,
  84. sortnum = build.sortnum,
  85. remark = build.remark,
  86. isdelete = build.isdelete,
  87. createtby = build.createtby,
  88. createtime = build.createtime,
  89. };
  90. var model = query.FirstOrDefault();
  91. if (model != null)
  92. {
  93. return model;
  94. }
  95. return null;
  96. }
  97. #endregion
  98. }
  99. }