深入实践Spring Boot3.1.3 分页查询设计

Neo4j分页查询设计
本文介绍了一种针对Neo4j数据库的分页查询设计方案,通过自定义服务类实现灵活的分页与排序功能,支持传入实体对象类型、页数及排序设定等参数。

3.1.3 分页查询设计

对于新型的Neo4j数据库来说,由于它的资源库遵循了JPA的规范标准来设计,在分页查询方面有的地方还不是很完善,所以在分页查询中,设计了一个服务类来处理,如代码清单3-3所示。其中,使用Class<T>传入调用的实体对象,使用Pageable传入页数设定和排序字段设定的参数,使用Filters传入查询的一些节点属性设定的参数。

代码清单3-3 Neo4j分页查询服务类

@Service

public class PagesService<T> {

    @Autowired

    private Session session;

 

    public Page<T> findAll(Class<T> clazz, Pageable pageable, Filters filters){

        Collection data = this.session.loadAll(clazz, filters, convert

(pageable.getSort()), new Pagination(pageable.getPageNumber(), pageable.getPageSize()), 1);

        return updatePage(pageable, new ArrayList(data));

    }

......

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值