颐和api

Knowledge_BaseRepository.cs 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. using MadRunFabric.Common;
  2. using MadRunFabric.Model;
  3. using CallCenterApi.IRepositories;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Text;
  7. using Microsoft.Extensions.Logging;
  8. using MadRunFabric.Common.Options;
  9. using Microsoft.Extensions.Options;
  10. using System.Linq;
  11. using MongoDB.Driver;
  12. namespace CallCenterApi.Repositories
  13. {
  14. public class Knowledge_BaseRepository : BaseRepository<Knowledge_Base, string>, IKnowledge_BaseRepository
  15. {
  16. protected readonly ILogger<BaseRepository<Knowledge_Base, string>> _logger;
  17. protected readonly IMongoCollection<Knowledge_Type> _collection_knowledge_type;
  18. public Knowledge_BaseRepository(IOptions<MongodbOptions> settings, ILogger<BaseRepository<Knowledge_Base, string>> logger) : base(settings, logger)
  19. {
  20. _logger = logger;
  21. _collection_knowledge_type = _context.GetCollection<Knowledge_Type>();
  22. }
  23. /// <summary>
  24. /// Linq 关联查询 分页
  25. /// </summary>
  26. /// <param name="key"></param>
  27. /// <param name="typeid"></param>
  28. /// <param name="stime"></param>
  29. /// <param name="etime"></param>
  30. /// <param name="pageindex"></param>
  31. /// <param name="pagesize"></param>
  32. /// <param name="recordCount"></param>
  33. /// <returns></returns>
  34. public IEnumerable<object> GetListsByPage(string key, string typeid, string stime, string etime, int pageindex, int pagesize, out int recordCount)
  35. {
  36. var query = from p in _collection.AsQueryable()
  37. join dic_type in _collection_knowledge_type.AsQueryable() on p.typeid equals dic_type.id into dic_typeDefa
  38. where p.isdelete == 0
  39. select new
  40. {
  41. p.id,
  42. p.typeid,
  43. typename = dic_typeDefa != null && dic_typeDefa.Count() > 0 ? dic_typeDefa.First().name : null,
  44. p.title,
  45. p.content,
  46. p.remark,
  47. p.createtime,
  48. p.createuser,
  49. p.createusername
  50. };
  51. #region 查询条件
  52. if (!string.IsNullOrEmpty(key))
  53. query = query.Where(it => it.title.Contains(key) || it.content.Contains(key));
  54. if (!string.IsNullOrEmpty(typeid))
  55. query = query.Where(it => it.typeid == typeid);
  56. if (!string.IsNullOrEmpty(stime))
  57. query = query.Where(it => it.createtime >= Convert.ToDateTime(stime + " 00:00:00"));
  58. if (!string.IsNullOrEmpty(etime))
  59. query = query.Where(it => it.createtime <= Convert.ToDateTime(etime + " 23:59:59"));
  60. #endregion
  61. recordCount = query.Count();
  62. var list = query.Skip((pageindex - 1) * pagesize).Take(pagesize).ToList();
  63. return list;
  64. }
  65. /// <summary>
  66. /// 详情 - 获取设备详情 by id
  67. /// </summary>
  68. /// <param name="id"></param>
  69. /// <returns></returns>
  70. public object GetDetails(string id)
  71. {
  72. var query = from p in _collection.AsQueryable()
  73. join dic_type in _collection_knowledge_type.AsQueryable() on p.typeid equals dic_type.id into dic_typeDefa
  74. where p.id == id
  75. select new
  76. {
  77. p.id,
  78. p.typeid,
  79. typename = dic_typeDefa != null && dic_typeDefa.Count() > 0 ? dic_typeDefa.First().name : null,
  80. p.title,
  81. p.content,
  82. p.remark,
  83. p.createtime,
  84. p.createuser,
  85. p.createusername
  86. };
  87. var info = query.FirstOrDefault();
  88. return info;
  89. }
  90. }
  91. }