栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

多数据源导致PageHelper失效

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

多数据源导致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  PagedResult toPagedResult(List datas) {
        PagedResult result = new PagedResult();
        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  PagedResult toPagedLimitResult(List datas, Integer pageNo, Integer pageSize, long count) {
        PagedResult result = new PagedResult();
        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 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 holdCombinedBos = commonPositionMapper.selectHoldCombined();
PagedResult holdCombinedBoPagedResult = PageHelperUtil.toPagedResult(holdCombinedBos);
配置多数据源时导致分页失效

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

 public static  PagedResult toPagedResult(List datas) {
        PagedResult result = new PagedResult();
        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();
    }

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/643766.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号