// namespace SafeCampus.System; /// /// /// public class OperateLogService : DbRepository, IOperateLogService { /// /// 操作日志中文名称 /// private readonly string _nameOperate = "操作日志"; /// /// 异常日志中文名称 /// private readonly string _nameException = "异常日志"; /// /// 分表最多查近多少年的数据 /// private readonly int _maxTabs = 100; /// public async Task> Page(OperateLogPageInput input) { var query = Context.Queryable().WhereIF(!string.IsNullOrEmpty(input.Account), it => it.OpAccount == input.Account)//根据账号查询 .WhereIF(!string.IsNullOrEmpty(input.Category), it => it.Category == input.Category)//根据分类查询 .WhereIF(!string.IsNullOrEmpty(input.SearchKey), it => it.Name.Contains(input.SearchKey) || it.OpIp.Contains(input.SearchKey))//根据关键字查询 .IgnoreColumns(it => new { it.ParamJson, it.ResultJson }).SplitTable(tabs => tabs.Take(_maxTabs)) .OrderByIF(!string.IsNullOrEmpty(input.SortField), $"{input.SortField} {input.SortOrder}")//排序 .OrderBy(it => it.CreateTime, OrderByType.Desc); var pageInfo = await query.ToPagedListAsync(input.PageNum, input.PageSize);//分页 return pageInfo; } /// public async Task> StatisticsByDay(int day) { //取最近七天 var dayArray = Enumerable.Range(0, day).Select(it => DateTime.Now.Date.AddDays(it * -1)).ToList(); //生成时间表 var queryableLeft = Context.Reportable(dayArray).ToQueryable(); //ReportableDateType.MonthsInLast1yea 表式近一年月份 并且queryable之后还能在where过滤 var queryableRight = Context.Queryable().SplitTable(tabs => tabs.Take(_maxTabs));//声名表 //报表查询 var list = await Context .Queryable(queryableLeft, queryableRight, JoinType.Left, (x1, x2) => x2.CreateTime.Value.ToString("yyyy-MM-dd") == x1.ColumnName.ToString("yyyy-MM-dd")) .GroupBy((x1, x2) => x1.ColumnName)//根据时间分组 .OrderBy((x1, x2) => x1.ColumnName)//根据时间升序排序 .Select((x1, x2) => new { OperateCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_OPERATE, 1, 0)),//null的数据要为0所以不能用count ExceptionCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_EXCEPTION, 1, 0)),//null的数据要为0所以不能用count Date = x1.ColumnName.ToString("yyyy-MM-dd") }).ToListAsync(); //定义返回结果 var result = new List(); //遍历结果 list.ForEach(it => { result.Add(new OperateLogDayStatisticsOutput { Date = it.Date, Name = _nameOperate, Count = it.OperateCount });//添加访问日志 result.Add(new OperateLogDayStatisticsOutput { Date = it.Date, Name = _nameException, Count = it.ExceptionCount });//添加异常日志 }); return result; } /// public async Task> TotalCount() { var data = await Context.Queryable().SplitTable(tabs => tabs.Take(_maxTabs)).GroupBy(it => it.Category)//根据分类分组 .Select(it => new { it.Category,//分类 Count = SqlFunc.AggregateCount(it.Category)//数量 }).ToListAsync(); //定义结果数组 var operateLogTotalCounts = new List { //添加操作日志数据 new OperateLogTotalCountOutput { Type = _nameOperate, Value = data.Where(it => it.Category == CateGoryConst.LOG_OPERATE).Select(it => it.Count).FirstOrDefault() }, //添加异常日志数据 new OperateLogTotalCountOutput { Type = _nameException, Value = data.Where(it => it.Category == CateGoryConst.LOG_EXCEPTION).Select(it => it.Count).FirstOrDefault() } }; return operateLogTotalCounts; } /// public async Task Delete(string category) { await Context.Deleteable().Where(it => it.Category == category).SplitTable(tabs => tabs.Take(_maxTabs)) .ExecuteCommandAsync();//删除对应分类日志 } /// public async Task Detail(BaseIdInput input) { return await GetFirstSplitTableAsync(it => it.Id == input.Id, tabs => tabs.Take(_maxTabs)); } }