颐和api

App_Version3DRepository.cs 4.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. using MadRunFabric.Common;
  2. using MadRunFabric.Common.Options;
  3. using MadRunFabric.Model;
  4. using MadRunFabric.Model.MessageApi;
  5. using MessageApi.IRepositories;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.Extensions.Options;
  8. using MongoDB.Driver;
  9. using System;
  10. using System.Collections.Generic;
  11. using System.Text;
  12. using System.Linq;
  13. namespace MessageApi.Repositories
  14. {
  15. public class App_Version3DRepository : BaseRepository<App_Version3D, string>, IApp_Version3DRepository
  16. {
  17. protected readonly ILogger<BaseRepository<App_Version3D, string>> _logger;
  18. protected readonly IMongoCollection<Pro_Project_Info> _collection_pro_project_info;
  19. public App_Version3DRepository(IOptions<MongodbOptions> settings, ILogger<BaseRepository<App_Version3D, string>> logger) : base(settings, logger)
  20. {
  21. _logger = logger;
  22. _collection_pro_project_info = _context.GetCollection<Pro_Project_Info>();
  23. }
  24. /// <summary>
  25. /// Linq 关联查询 分页
  26. /// </summary>
  27. /// <param name="ordercode"></param>
  28. /// <param name="key"></param>
  29. /// <param name="phone"></param>
  30. /// <param name="province"></param>
  31. /// <param name="city"></param>
  32. /// <param name="sourceid"></param>
  33. /// <param name="typeid"></param>
  34. /// <param name="deptid"></param>
  35. /// <param name="stime"></param>
  36. /// <param name="etime"></param>
  37. /// <param name="state"></param>
  38. /// <param name="pageindex"></param>
  39. /// <param name="pagesize"></param>
  40. /// <param name="recordCount"></param>
  41. /// <returns></returns>
  42. public IEnumerable<object> GetListsByPage(int apptype, string projectid, string keyword, string stime, string etime, int pageindex, int pagesize, out int recordCount)
  43. {
  44. var query = from p in _collection.AsQueryable()
  45. join pro in _collection_pro_project_info.AsQueryable() on p.projectid equals pro.id into proDefa
  46. where p.isdelete == 0
  47. orderby p.createtime descending
  48. select new
  49. {
  50. p.id,
  51. p.apptype,
  52. p.projectid,
  53. projectname = proDefa != null && proDefa.Count() > 0 ? proDefa.First().project_name : null,
  54. p.versionname,
  55. p.versioncode,
  56. p.downurl,
  57. p.createby,
  58. p.createtime,
  59. p.updatetime,
  60. p.note
  61. };
  62. #region 查询条件
  63. if (!string.IsNullOrEmpty(keyword))
  64. query = query.Where(it => it.versionname.Contains(keyword) || it.versioncode.Contains(keyword));
  65. if (apptype > 0)
  66. query = query.Where(it => it.apptype == apptype);
  67. if (!string.IsNullOrEmpty(projectid))
  68. query = query.Where(it => it.projectid == projectid);
  69. if (!string.IsNullOrEmpty(stime))
  70. query = query.Where(it => it.createtime >= Convert.ToDateTime(stime + " 00:00:00"));
  71. if (!string.IsNullOrEmpty(etime))
  72. query = query.Where(it => it.createtime <= Convert.ToDateTime(etime + " 23:59:59"));
  73. #endregion
  74. recordCount = query.Count();
  75. var list = query.Skip((pageindex - 1) * pagesize).Take(pagesize).ToList();
  76. return list;
  77. }
  78. /// <summary>
  79. /// 详情 - 获取工单详情 by id
  80. /// </summary>
  81. /// <param name="id"></param>
  82. /// <returns></returns>
  83. public object GetDetails(string id)
  84. {
  85. var query = from p in _collection.AsQueryable()
  86. join pro in _collection_pro_project_info.AsQueryable() on p.projectid equals pro.id into proDefa
  87. where p.id == id
  88. select new
  89. {
  90. p.id,
  91. p.apptype,
  92. p.projectid,
  93. projectname = proDefa != null && proDefa.Count() > 0 ? proDefa.First().project_name : null,
  94. p.versionname,
  95. p.versioncode,
  96. p.downurl,
  97. p.createby,
  98. p.createtime,
  99. p.updatetime,
  100. p.note
  101. };
  102. var info = query.FirstOrDefault();
  103. return info;
  104. }
  105. }
  106. }