refactor: 重构优化db模块抽象
This commit is contained in:
@@ -7,6 +7,7 @@ using Yi.Framework.Bbs.Application.Contracts.Dtos.BbsUser;
|
||||
using Yi.Framework.Bbs.Domain.Entities;
|
||||
using Yi.Framework.Bbs.Domain.Managers;
|
||||
using Yi.Framework.Rbac.Application.Contracts.IServices;
|
||||
using Yi.Framework.Rbac.Domain.Authorization;
|
||||
using Yi.Framework.Rbac.Domain.Shared.Consts;
|
||||
using Yi.Framework.Rbac.Domain.Shared.Model;
|
||||
|
||||
@@ -29,13 +30,16 @@ namespace Yi.Framework.Bbs.Application.Services.Analyses
|
||||
[HttpGet("analyse/bbs-user/random")]
|
||||
public async Task<List<BbsUserGetListOutputDto>> GetRandomUserAsync([FromQuery] PagedResultRequestDto input)
|
||||
{
|
||||
var randUserIds = await _bbsUserManager._userRepository._DbQueryable
|
||||
//.Where(x => x.UserName != UserConst.Admin)
|
||||
// using (DataFilter.DisablePermissionHandler())
|
||||
{
|
||||
var randUserIds = await _bbsUserManager._userRepository._DbQueryable
|
||||
//.Where(x => x.UserName != UserConst.Admin)
|
||||
.OrderBy(x => SqlFunc.GetRandom())
|
||||
.Select(x => x.Id).
|
||||
ToPageListAsync(input.SkipCount, input.MaxResultCount);
|
||||
var output = await _bbsUserManager.GetBbsUserInfoAsync(randUserIds);
|
||||
return output.Adapt<List<BbsUserGetListOutputDto>>();
|
||||
var output = await _bbsUserManager.GetBbsUserInfoAsync(randUserIds);
|
||||
return output.Adapt<List<BbsUserGetListOutputDto>>();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -45,14 +49,17 @@ namespace Yi.Framework.Bbs.Application.Services.Analyses
|
||||
[HttpGet("analyse/bbs-user/integral-top")]
|
||||
public async Task<List<BbsUserGetListOutputDto>> GetIntegralTopUserAsync([FromQuery] PagedResultRequestDto input)
|
||||
{
|
||||
var randUserIds = await _bbsUserManager._userRepository._DbQueryable
|
||||
// .Where(user => user.UserName != UserConst.Admin)
|
||||
.LeftJoin<BbsUserExtraInfoEntity>((user, info) => user.Id==info.UserId)
|
||||
.OrderByDescending((user, info)=>info.Money)
|
||||
// using (DataFilter.DisablePermissionHandler())
|
||||
{
|
||||
var randUserIds = await _bbsUserManager._userRepository._DbQueryable
|
||||
// .Where(user => user.UserName != UserConst.Admin)
|
||||
.LeftJoin<BbsUserExtraInfoEntity>((user, info) => user.Id == info.UserId)
|
||||
.OrderByDescending((user, info) => info.Money)
|
||||
.Select((user, info) => user.Id).
|
||||
ToPageListAsync(input.SkipCount, input.MaxResultCount);
|
||||
var output = await _bbsUserManager.GetBbsUserInfoAsync(randUserIds);
|
||||
return output.OrderByDescending(x=>x.Money).ToList().Adapt<List<BbsUserGetListOutputDto>>();
|
||||
var output = await _bbsUserManager.GetBbsUserInfoAsync(randUserIds);
|
||||
return output.OrderByDescending(x => x.Money).ToList().Adapt<List<BbsUserGetListOutputDto>>();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@@ -62,22 +69,24 @@ namespace Yi.Framework.Bbs.Application.Services.Analyses
|
||||
[HttpGet("analyse/bbs-user")]
|
||||
public async Task<BbsUserAnalyseGetOutput> GetUserAnalyseAsync()
|
||||
{
|
||||
|
||||
var registerUser = await _bbsUserManager._userRepository._DbQueryable.CountAsync();
|
||||
// using (DataFilter.DisablePermissionHandler())
|
||||
{
|
||||
var registerUser = await _bbsUserManager._userRepository._DbQueryable.CountAsync();
|
||||
|
||||
|
||||
DateTime now = DateTime.Now;
|
||||
DateTime yesterday = now.AddDays(-1);
|
||||
DateTime startTime = new DateTime(yesterday.Year, yesterday.Month, yesterday.Day, 0, 0, 0);
|
||||
DateTime endTime = startTime.AddHours(24);
|
||||
var yesterdayNewUser = await _bbsUserManager._userRepository._DbQueryable
|
||||
.Where(x => x.CreationTime >= startTime && x.CreationTime <= endTime).CountAsync();
|
||||
DateTime now = DateTime.Now;
|
||||
DateTime yesterday = now.AddDays(-1);
|
||||
DateTime startTime = new DateTime(yesterday.Year, yesterday.Month, yesterday.Day, 0, 0, 0);
|
||||
DateTime endTime = startTime.AddHours(24);
|
||||
var yesterdayNewUser = await _bbsUserManager._userRepository._DbQueryable
|
||||
.Where(x => x.CreationTime >= startTime && x.CreationTime <= endTime).CountAsync();
|
||||
|
||||
var userOnline = (await _onlineService.GetListAsync(new OnlineUserModel { })).TotalCount;
|
||||
var userOnline = (await _onlineService.GetListAsync(new OnlineUserModel { })).TotalCount;
|
||||
|
||||
var output = new BbsUserAnalyseGetOutput() { OnlineNumber = userOnline, RegisterNumber = registerUser, YesterdayNewUser = yesterdayNewUser };
|
||||
var output = new BbsUserAnalyseGetOutput() { OnlineNumber = userOnline, RegisterNumber = registerUser, YesterdayNewUser = yesterdayNewUser };
|
||||
|
||||
return output;
|
||||
return output;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user