颐和api

Ask_QuestionPagerRepository.cs 3.4KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. using CallCenterApi.IRepositories;
  2. using MadRunFabric.Common;
  3. using MadRunFabric.Common.Options;
  4. using MadRunFabric.Model.CallCenterApi;
  5. using Microsoft.Extensions.Logging;
  6. using Microsoft.Extensions.Options;
  7. using MongoDB.Driver;
  8. using System;
  9. using System.Collections.Generic;
  10. using System.Text;
  11. using System.Linq;
  12. namespace CallCenterApi.Repositories
  13. {
  14. public class Ask_QuestionPagerRepository : BaseRepository<Ask_QuestionPager, string>, IAsk_QuestionPagerRepository
  15. {
  16. protected readonly ILogger<BaseRepository<Ask_QuestionPager, string>> _logger;
  17. //protected readonly IMongoCollection<mw_call_records> _collection_mw_call_records;
  18. protected readonly IMongoCollection<Ask_QuestionPager> _collection_ask_questionpager;
  19. protected readonly IMongoCollection<Ask_Question> _collection_ask_question;
  20. protected readonly IMongoCollection<Ask_QuestionItems> _collection_ask_questionitems;
  21. public Ask_QuestionPagerRepository(IOptions<MongodbOptions> settings, ILogger<BaseRepository<Ask_QuestionPager, string>> logger) : base(settings, logger)
  22. {
  23. _logger = logger;
  24. //_collection_mw_call_records = _context.GetCollection<mw_call_records>();
  25. _collection_ask_questionpager = _context.GetCollection<Ask_QuestionPager>();
  26. _collection_ask_question = _context.GetCollection<Ask_Question>();
  27. _collection_ask_questionitems = _context.GetCollection<Ask_QuestionItems>();
  28. }
  29. /// <summary>
  30. /// 分页列表
  31. /// </summary>
  32. /// <param name="usercode"></param>
  33. /// <param name="calltype"></param>
  34. /// <param name="telephone"></param>
  35. /// <param name="checktype"></param>
  36. /// <param name="stime"></param>
  37. /// <param name="etime"></param>
  38. /// <param name="pageindex"></param>
  39. /// <param name="pagesize"></param>
  40. /// <param name="recordcount"></param>
  41. /// <returns></returns>
  42. public IEnumerable<object> GetPageListsByPage(string keyword, string usercode, string stime, string etime, int pageindex, int pagesize, out int recordcount)
  43. {
  44. var query = from p in _collection_ask_questionpager.AsQueryable()
  45. where p.isdelete == 0
  46. select new
  47. {
  48. p.id,
  49. p.title,
  50. p.totalnum,
  51. p.remark,
  52. p.createtime,
  53. p.createuser,
  54. p.isopen
  55. };
  56. #region 查询条件
  57. if (!string.IsNullOrEmpty(keyword))
  58. query = query.Where(it => it.title.Contains(keyword) || it.remark.Contains(keyword));
  59. if (!string.IsNullOrEmpty(usercode))
  60. query = query.Where(it => it.createuser == usercode);
  61. if (!string.IsNullOrEmpty(stime))
  62. query = query.Where(it => it.createtime >= Convert.ToDateTime(stime + " 00:00:00"));
  63. if (!string.IsNullOrEmpty(etime))
  64. query = query.Where(it => it.createtime <= Convert.ToDateTime(etime + " 23:59:59"));
  65. #endregion
  66. recordcount = query.Count();
  67. var list = query.Skip((pageindex - 1) * pagesize).Take(pagesize).ToList();
  68. return list;
  69. }
  70. }
  71. }