平安校园
Não pode escolher mais do que 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

SmsLogService.cs 4.3 KiB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. namespace SafeCampus.System.Services.LogAudit.SmsLog;
  2. public class SmsLogService : DbRepository<SysLogVisit>, ISmsLogService
  3. {
  4. /// <summary>
  5. /// 分表最多查近多少年的数据
  6. /// </summary>
  7. private readonly int _maxTabs = 100;
  8. /// <inheritdoc />
  9. public async Task<SqlSugarPagedList<SysLogVisit>> Page(SmsLogPageInput input)
  10. {
  11. var query = Context.Queryable<SysLogVisit>()
  12. .Where(x=>x.Category== CateGoryConst.CONFIG_SYS_ALARM_SMS)
  13. //.WhereIF(!string.IsNullOrEmpty(input.Account), it => it.OpAccount == input.Account)//根据账号查询
  14. //.WhereIF(!string.IsNullOrEmpty(input.Category), it => it.Category == input.Category)//根据分类查询
  15. .WhereIF(!string.IsNullOrEmpty(input.SearchKey), it => it.OpAccount.Contains(input.SearchKey) || it.OpUser.Contains(input.SearchKey)||it.OpAddress.Contains(input.SearchKey))//根据关键字查询
  16. .SplitTable(tabs => tabs.Take(_maxTabs))
  17. .OrderByIF(!string.IsNullOrEmpty(input.SortField), $"{input.SortField} {input.SortOrder}")//排序
  18. .OrderBy(it => it.CreateTime, OrderByType.Desc);
  19. var pageInfo = await query.ToPagedListAsync(input.PageNum, input.PageSize);//分页
  20. return pageInfo;
  21. }
  22. /// <inheritdoc />
  23. public async Task<List<SmsLogDayStatisticsOutput>> StatisticsByDay(int day)
  24. {
  25. //取最近七天
  26. var dayArray = Enumerable.Range(0, day).Select(it => DateTime.Now.Date.AddDays(it * -1)).ToList();
  27. //生成时间表
  28. var queryableLeft = Context.Reportable(dayArray).ToQueryable<DateTime>();
  29. //ReportableDateType.MonthsInLast1yea 表式近一年月份 并且queryable之后还能在where过滤
  30. var queryableRight = Context.Queryable<SysLogVisit>().SplitTable(tabs => tabs.Take(_maxTabs));//声名表
  31. //报表查询
  32. var list = await Context
  33. .Queryable(queryableLeft, queryableRight, JoinType.Left,
  34. (x1, x2) => x2.CreateTime.Value.ToString("yyyy-MM-dd") == x1.ColumnName.ToString("yyyy-MM-dd"))
  35. .GroupBy((x1, x2) => x1.ColumnName)//根据时间分组
  36. .OrderBy((x1, x2) => x1.ColumnName)//根据时间升序排序
  37. .Select((x1, x2) => new SmsLogDayStatisticsOutput
  38. {
  39. SuccessCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.CONFIG_SYS_ALARM_SMS&&x2.ExeStatus== SysLogConst.SUCCESS, 1, 0)),//null的数据要为0所以不能用count
  40. FailCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.CONFIG_SYS_ALARM_SMS&&x2.ExeStatus==SysLogConst.FAIL, 1, 0)),//null的数据要为0所以不能用count
  41. Date = x1.ColumnName.ToString("yyyy-MM-dd")
  42. }).ToListAsync();
  43. return list;
  44. }
  45. /// <inheritdoc />
  46. public async Task<List<SmsLogTotalCountOutput>> TotalCount()
  47. {
  48. var data = await Context.Queryable<SysLogVisit>().SplitTable(tabs => tabs.Take(_maxTabs)).GroupBy(it => new{ it.Category ,it.ExeStatus})//根据分类分组
  49. .Select(it => new
  50. {
  51. it.Category,//分类
  52. it.ExeStatus,
  53. Count = SqlFunc.AggregateCount(it.Category)//数量
  54. }).ToListAsync();
  55. //定义结果数组
  56. var SmsLogTotalCounts = new List<SmsLogTotalCountOutput>
  57. {
  58. //添加登录数据
  59. new SmsLogTotalCountOutput
  60. {
  61. Type = EventSubscriberConst.SMS_SUCCESS,
  62. Value = data.Where(it => it.Category == CateGoryConst.CONFIG_SYS_ALARM_SMS&&it.ExeStatus==SysLogConst.SUCCESS).Select(it => it.Count).FirstOrDefault()
  63. },
  64. //添加登出数据
  65. new SmsLogTotalCountOutput
  66. {
  67. Type = EventSubscriberConst.SMS_FAIL,
  68. Value = data.Where(it => it.Category == CateGoryConst.CONFIG_SYS_ALARM_SMS&&it.ExeStatus==SysLogConst.FAIL).Select(it => it.Count).FirstOrDefault()
  69. }
  70. };
  71. return SmsLogTotalCounts;
  72. }
  73. /// <inheritdoc />
  74. public async Task Delete()
  75. {
  76. await Context.Deleteable<SysLogVisit>().Where(it => it.Category == CateGoryConst.CONFIG_SYS_ALARM_SMS).SplitTable(tabs => tabs.Take(_maxTabs))
  77. .ExecuteCommandAsync();//删除对应分类日志
  78. }
  79. }