ABP学习笔记:分页的实现

84 篇文章 0 订阅

SkipCount:跳转数量,一般计算公式为SkipCount=Page*MaxResultCount(页数*行数)

一、分页请求DTO定义
数据传输对象(Data Transfer Objects)用于应用层和展现层的数据传输。
展现层传入数据传输对象(DTO)调用一个应用服务方法,接着应用服务通过领域对象执行一些特定的业务逻辑并且返回DTO给展现层。这样展现层和领域层被完全分离开了。在具有良好分层的应用程序中,展现层不会直接使用领域对象(仓库,实体)。

我们在展现层有分页请求时,一般需要指定两个参数,一个用来标志第几页、一个是每页行数(一般有配置文件配置)。
因为分页是一个很常用的功能,所以,展现层我们有分页请求时,最好有相应的DTO来封装这两个参数。
在ABP源码中并没有为我们封装这样公用的类,但是在ABPZero项目中,定义了相应的分页Dto。
对应的类图如下:

从中可以看到主要包括以下四个公共DTO定义:

PagedInputDto:分页请求Dto
PagedAndSortedInputDto:分页排序Dto
PagedSortedAndFilteredInputDto:分页排序过滤Dto
PagedAndFilteredInputDto:分页过滤Dto
是不是很实用,我们的分页一般是和过滤排序混合使用的。

其中主要定义了以下几个主要属性:

MaxResultCount:每页行数,可以从定义的配置中读取。
SkipCount:跳转数量,一般计算公式为SkipCount=Page*MaxResultCount(页数*行数)。
Filter:过滤字符串
Sorting:排序方式
具体的实现就不详述了,相信仔细看类图,就能自己动手实现。AbpZero把这些公共Dto定义在了应用服务层的Dto文件夹下,具体路径如下图。

二、如何使用分页DTO
拿我们的任务清单举例,我们修改下创建的GetTaskInputDto,让它继承自PagedSortedAndFilteredInputDto,这样GetTaskInputDto就拥有了进行分页排序过滤需要用到的属性。

public class GetTasksInput : PagedSortedAndFilteredInputDto
{
    public TaskState? State { get; set; }
 
    public int? AssignedPersonId { get; set; }
}


三、返回分页结果DTO
Abp已经为我们定义了泛型的PagedResultDto用来包装返回的分页结果。其中主要包括两个属性,int TotalCount保存总个数,IReadOnlyList<T> Items保存返回的分页结果集。

四、应用服务层分页逻辑实现
1、在ITaskAppService中添加接口定义:

PagedResultDto<TaskDto> GetPagedTasks(GetTasksInput input);


2、在TaskAppService中实现接口:

public PagedResultDto<TaskDto> GetPagedTasks(GetTasksInput input)
{
    //初步过滤
    var query = _taskRepository.GetAll().Include(t => t.AssignedPerson)
        .WhereIf(input.State.HasValue, t => t.State == input.State.Value)
        .WhereIf(!input.Filter.IsNullOrEmpty(), t => t.Title.Contains(input.Filter))
        .WhereIf(input.AssignedPersonId.HasValue, t => t.AssignedPersonId == input.AssignedPersonId.Value);
 
    //排序
    query = !string.IsNullOrEmpty(input.Sorting) ? query.OrderBy(input.Sorting) : query.OrderByDescending(t => t.CreationTime);
 
    //获取总数
    var tasksCount = query.Count();
    //默认的分页方式
    //var taskList = query.Skip(input.SkipCount).Take(input.MaxResultCount).ToList();
 
    //ABP提供了扩展方法PageBy分页方式
    var taskList = query.PageBy(input).ToList();
 
    return new PagedResultDto<TaskDto>(tasksCount,taskList.MapTo<List<TaskDto>>());
}


分页的实现很简单,先进行过滤,排序,再进行分页,最后使用PagedResultDto封装分页结果。
细心的你也许发现了两个未曾在Linq中用过的方法WhereIf和PageBy,是的,这是ABP提供的扩展方法,感兴趣的可以看下源码QueryableExtensions的具体实现,其实实现的很简单,但我们平时在使用linq时却未必能想得到。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
ABP框架中,实现租户功能需要以下步骤: 1. 定义租户实体 在应用程序中定义一个租户实体,用于保存租户的信息。可以在实体中定义一些用于多租户的属性,例如数据库连接字符串、数据库架构名称等。 2. 实现租户存储库 创建一个租户存储库,用于对租户实体进行CRUD操作。在存储库中,可以使用ABP框架提供的标准CRUD方法,例如GetAsync、InsertAsync、UpdateAsync等。 3. 实现租户管理器 创建一个租户管理器,用于获取当前租户的信息。在管理器中,可以使用ABP框架提供的多租户上下文对象(MultiTenancyContext)来获取当前租户的ID和名称等信息。 4. 实现租户过滤器 创建一个租户过滤器,用于在数据访问时自动为当前租户添加过滤条件。在过滤器中,可以使用ABP框架提供的多租户上下文对象来获取当前租户的数据库架构名称等信息,然后在执行SQL查询时添加过滤条件。 5. 配置ABP框架 最后,在ABP框架的配置文件中配置多租户相关的选项,例如租户管理器、租户过滤器等。可以使用ABP框架提供的依赖注入功能自动注入租户管理器和租户过滤器。 通过以上步骤,我们就可以实现租户功能,并且保证租户之间的数据隔离和安全性。需要注意的是,在实现多租户功能时,要合理使用租户ID、租户名称和数据库连接字符串等信息,以保证租户数据的正确性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

董厂长

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值