多数据源导致PageHelper失效

启动加载PageHelper


@Configuration
public class MyBatisConfiguration {

    private static final Logger logger = LoggerFactory.getLogger(MyBatisConfiguration.class);

    @Bean
    public PageHelper pageHelper() {
        logger.info("注册mybatis分页插件PageHelper");
        PageHelper pageHelper = new PageHelper();
        Properties p = new Properties();
        p.setProperty("offsetAsPageNum", "true");
        p.setProperty("rowBoundsWithCount", "true");
        p.setProperty("reasonable", "true");
        pageHelper.setProperties(p);
        return pageHelper;
    }
}



工具类进一步验证Page实例(带内存分页)

public class PageHelperUtil {
    @SuppressWarnings("unchecked")
    public static <T> PagedResult<T> toPagedResult(List<T> datas) {
        PagedResult<T> result = new PagedResult<T>();
        if (datas instanceof Page) {
            @SuppressWarnings("rawtypes")
            Page page = (Page) datas;
            result.setPageNo(page.getPageNum());
            result.setPageSize(page.getPageSize());
            result.setDataList(page.getResult());
            result.setTotal(page.getTotal());
            result.setPages(page.getPages());
        } else {
            result.setPageNo(1);
            result.setPageSize(datas.size());
            result.setDataList(datas);
            result.setTotal(datas.size());
        }
        return result;
    }

    public static <T> PagedResult<T> toPagedLimitResult(List<T> datas, Integer pageNo, Integer pageSize, long count) {
        PagedResult<T> result = new PagedResult<T>();
        if (CollectionUtils.isEmpty(datas)) {
            result.setPageNo(pageNo);
            result.setPageSize(pageSize);
            result.setDataList(new ArrayList<>());
            result.setTotal(0);
            result.setPages(0);
            result.setReadCount(count);
            return result;
        }

        int pages = datas.size() / pageSize;
        int totalRowNum = datas.size();
        int fromIdx = (pageNo - 1) * pageSize;
        int toIdx = pageNo * pageSize > totalRowNum ? totalRowNum : pageNo * pageSize;
        if (datas.size() % pageSize != 0) {
            pages++;
        }
        if (fromIdx > toIdx) {
            result.setPageNo(pageNo);
            result.setPageSize(pageSize);
            result.setDataList(new ArrayList<>());
            result.setTotal(datas.size());
            result.setPages(pages);
            result.setReadCount(count);
            return result;
        }

        List<T> dataList = datas.subList(fromIdx, toIdx);
        result.setPageNo(pageNo);
        result.setPageSize(pageSize);
        result.setDataList(dataList);
        result.setTotal(datas.size());
        result.setPages(pages);
        result.setReadCount(count);
        return result;
    }

}

如何使用

PageHelper.startPage(pageNo, pageSize);
List<HoldCombinedBo> holdCombinedBos = commonPositionMapper.selectHoldCombined();
PagedResult<HoldCombinedBo> holdCombinedBoPagedResult = PageHelperUtil.toPagedResult(holdCombinedBos);

配置多数据源时导致分页失效

查询的集合不是Page的实例导致分页失效

 public static <T> PagedResult<T> toPagedResult(List<T> datas) {
        PagedResult<T> result = new PagedResult<T>();
        if (datas instanceof Page) {
        }else {
            result.setPageNo(1);
            result.setPageSize(datas.size());
            result.setDataList(datas);
            result.setTotal(datas.size());
        }
        return null;
}

如何解决

使用SqlSessionFactory重新加载pageHelper

 	@Bean(name = "primarySqlSessionFactory")
    @Primary
    public SqlSessionFactory primarySqlSessionFactory(@Qualifier("primaryDataSource") DataSource primaryDataSource)
            throws Exception {
        final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
        sessionFactory.setDataSource(primaryDataSource);
        // 重新加载pageHelper
        sessionFactory.setPlugins(pageHelper());
        sessionFactory.setMapperLocations(new PathMatchingResourcePatternResolver()
                .getResources(MAPPER_LOCATION));
        sessionFactory.setConfiguration(globalConfiguration());
        return sessionFactory.getObject();
    }

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值