颐和api

Sys_AuthorizationU3DRepository.cs 3.5KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. using ConfigurationApi.IRepositories;
  2. using ConfigurationApi.Model.Dto;
  3. using MadRunFabric.Common;
  4. using MadRunFabric.Common.Options;
  5. using MadRunFabric.Model;
  6. using MadRunFabric.Model.ConfigurationApi.Model;
  7. using Microsoft.Extensions.Logging;
  8. using Microsoft.Extensions.Options;
  9. using MongoDB.Driver;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.Text;
  13. using System.Linq;
  14. namespace ConfigurationApi.Repositories
  15. {
  16. public class Sys_AuthorizationU3DRepository : BaseRepository<Sys_AuthorizationU3D, string>, ISys_AuthorizationU3DRepository
  17. {
  18. protected readonly ILogger<BaseRepository<Sys_AuthorizationU3D, string>> _logger;
  19. protected readonly IMongoCollection<Pro_Project_Info> _collection_pro_project_info;
  20. public Sys_AuthorizationU3DRepository(
  21. IOptions<MongodbOptions> settings,
  22. ILogger<BaseRepository<Sys_AuthorizationU3D, string>> logger) :
  23. base(settings, logger)
  24. {
  25. _logger = logger;
  26. _collection_pro_project_info = _context.GetCollection<Pro_Project_Info>();//获取集合
  27. }
  28. /// <summary>
  29. /// Linq 关联查询 分页
  30. /// </summary>
  31. /// <param name="keyword"></param>
  32. /// <param name="projectid"></param>
  33. /// <param name="isopen"></param>
  34. /// <param name="pageindex"></param>
  35. /// <param name="pagesize"></param>
  36. /// <param name="recordCount"></param>
  37. /// <returns></returns>
  38. public IEnumerable<U3DDto> GetListsByPage(string keyword, string projectid, string stime, string etime, int isopen, int pageindex, int pagesize, out int recordCount)
  39. {
  40. var query =
  41. from p in _collection.AsQueryable()
  42. join pro in _collection_pro_project_info.AsQueryable() on p.projectid equals pro.id into projeDefa
  43. where p.isdelete == 0
  44. orderby p.createtime descending
  45. select new U3DDto
  46. {
  47. id = p.id,
  48. authorizationcode = p.authorizationcode,
  49. projectid = p.projectid,
  50. projectname = projeDefa.Count() > 0 ? projeDefa.First().project_name : "",
  51. duedate = p.duedate,
  52. //duedate = p.duedate.ToString("yyyy-MM-dd"),
  53. //duedate_day = (DateTime.Parse(p.duedate.ToString()) - DateTime.Now).Days, //剩余到期天数
  54. ip = p.ip,
  55. isopen = p.isopen,
  56. createtime = p.createtime,
  57. isdelete = p.isdelete,
  58. remark = p.remark
  59. };
  60. #region 查询条件
  61. if (isopen > -1)
  62. query = query.Where(it => it.isopen == isopen);
  63. if (!string.IsNullOrEmpty(projectid))
  64. query = query.Where(it => it.projectid.Equals(projectid));
  65. if (!string.IsNullOrEmpty(keyword))
  66. query = query.Where(it => it.authorizationcode.Contains(keyword) || it.remark.Contains(keyword));
  67. if (!string.IsNullOrEmpty(stime))
  68. query = query.Where(it => it.duedate >= Convert.ToDateTime(stime + " 00:00:00"));
  69. if (!string.IsNullOrEmpty(etime))
  70. query = query.Where(it => it.duedate <= Convert.ToDateTime(etime + " 23:59:59"));
  71. #endregion
  72. recordCount = query.Count();
  73. var list = query.OrderByDescending(it => it.createtime).Skip((pageindex - 1) * pagesize).Take(pagesize);
  74. return list;
  75. }
  76. }
  77. }