Mybatis使用PageHelper插件---多表在同一个分页环境展示数据

本文介绍如何使用Mybatis的PageHelper插件,实现基于共同字段domain的多表分页查询。通过创建ThreeTypesDomainVo实体类,将三个无直接联系的表数据整合并进行分页展示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

同时分页展示,三个表包含共同字段domain,其他字段无联系。以domain为查询条件进行分页,ThreeTypesDomainVo为拼接三个表的实体类。
代码:

/**
 * 
 * @param domain 查询参数(忽略)
 * @param pageNo
 * @param pageSize
 * @return
 */
public PageInfo<ThreeTypesDomainVo> getDomainList(String domain, int pageNo, int pageSize){
    
    int max=getMax(domainFilterurlMapper.getCount(domain),domainNotmatchurlMapper.getCount(domain),domainRulemetricMapper.getCount(domain));  
    com.github.pagehelper.Page page0=null;
    if (domainFilterurlMapper.getCount(domain)==max){  //以数据条数最多的为标准分页
        PageHelper.startPage(pageNo, pageSize);
        List<DomainFilterurl> list11 = domainFilterurlMapper.selectAllByDomain(domain);
        PageInfo<DomainFilterurl> pageInfo = new PageInfo<>(list11);
        page0= new com.github.pagehelper.Page(pageInfo.getPageNum(), pageInfo.getPageSize());
        page0.setTotal(pageInfo.getTotal());
        int flag=page0.getStartRow();
        for (DomainFilterurl domainFilterurl:list11) {
            flag++;
            //String domainPv1=null;
            String domainPv2=null;
            String domainPv3=null;
            //String domain1=null;
            String domain2=null;
            String domain3=null;
            List<DomainNotmatchurl> list2=domainNotmatchurlMapper.selectAllByDomain(domain);
            List<DomainRulemetric> list3=domainRulemetricMapper.selectAllByDomain(domain);
            if (list2.size()>=flag){  //判断其他两个表是否还有数据
                domainPv2=list2.get(flag-1).getDomainPv();
                domain2=list2.get(flag-1).getDomain();
            }
            if (list3.size()>=flag){
                domainPv3=list3.get(flag-1).getDomainPv();
                domain3=list3.get(flag-1).getDomain();
            }
            ThreeTypesDomainVo threeTypesDomainVo=new ThreeTypesDomainVo(domainFilterurl.getDomain(),domainFilterurl.getDomainPv(),null,domain2,domainPv2,null,domain3,domainPv3,null);
            page0.add(threeTypesDomainVo);
        }
    }else if (domainNotmatchurlMapper.getCount(domain)==max){
       同理......
        }
    }else if (domainRulemetricMapper.getCount(domain)==max){
       同理......
        }
    }
    return new PageInfo<ThreeTypesDomainVo>(page0);
}

代码水平一般~~ 欢迎大家批评指正----

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值