// namespace SafeCampus.System; /// /// /// public class VisitLogService : DbRepository, IVisitLogService { /// /// 分表最多查近多少年的数据 /// private readonly int _maxTabs = 100; /// public async Task> Page(VisitLogPageInput 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))//根据关键字查询 .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 VisitLogDayStatisticsOutput { LoginCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_LOGIN, 1, 0)),//null的数据要为0所以不能用count LogoutCount = SqlFunc.AggregateSum(SqlFunc.IIF(x2.Category == CateGoryConst.LOG_LOGOUT, 1, 0)),//null的数据要为0所以不能用count Date = x1.ColumnName.ToString("yyyy-MM-dd") }).ToListAsync(); return list; } /// 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 visitLogTotalCounts = new List { //添加登录数据 new VisitLogTotalCountOutput { Type = EventSubscriberConst.LOGIN_B, Value = data.Where(it => it.Category == CateGoryConst.LOG_LOGIN).Select(it => it.Count).FirstOrDefault() }, //添加登出数据 new VisitLogTotalCountOutput { Type = EventSubscriberConst.LOGIN_OUT_B, Value = data.Where(it => it.Category == CateGoryConst.LOG_LOGOUT).Select(it => it.Count).FirstOrDefault() } }; return visitLogTotalCounts; } /// public async Task Delete(string category) { await Context.Deleteable().Where(it => it.Category == category).SplitTable(tabs => tabs.Take(_maxTabs)) .ExecuteCommandAsync();//删除对应分类日志 } }