利用java反射解决Mybatis Pagehelper插件联表查询分页不准确的问题(二)

简介: 利用java反射解决Mybatis Pagehelper插件联表查询分页不准确的问题

CompanyWhere 源码:

package com.easy.xdo;
import lombok.Data;
@Data
public class CompanyWhere extends CompanyDO{
  /**
     * page -1 默认不分页
     */
    private int page;
    private int rows;
    private int startrow;
    private String suffix;
}

CompanyParam 源码:


package com.easy.xdo;
import lombok.Data;
@Data
public class CompanyParam {
  private CompanyDO xdo;
  private CompanyWhere where;
}

EmployeDO源码:

package com.easy.xdo;
import lombok.Data;
@Data
public class EmployeDO {
    //演示员工类
  private String id;
  private String name;
  private String age;
  private String companyid;
}

CompanyController源码:

package com.easy.controller;
import io.swagger.annotations.Api;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.easy.service.CompanyService;
import com.easy.util.PageUtil;
import com.easy.xbo.PageBO;
import com.easy.xdo.CompanyParam;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import io.swagger.annotations.ApiOperation;
@Api("API-公司接口")
@RestController
@RequestMapping("api/v1/company")
public class CompanyController {
  @Autowired
    private CompanyService companyService;
  @ApiOperation(value = "分页查询")
    @PostMapping("/page")
    public PageBO page() throws Exception{
    CompanyParam param=new CompanyParam();
        return PageUtil.getPageBOData(companyService,param);
    }
}

CompanyService 源码:

package com.easy.service;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import com.easy.dao.CompanyDAO;
import com.easy.xdo.CompanyDO;
import com.easy.xdo.CompanyParam;
public class CompanyService {
  @Autowired
  private CompanyDAO companyDAO;
  public List<CompanyDO> selectPage(CompanyParam param){
        return companyDAO.selectList(param);
    }
    public int selectCount(CompanyParam param){
        return companyDAO.selectCount(param);
    }
}


xml源码

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.easy.dao.CompanyDAO">
  <resultMap id="BaseResultMap" type="com.easy.xdo.CompanyDO">
    <id column="id" property="id" />
    <result column="name" property="name" />
    <result column="address" property="address" />
    <collection property="employes" ofType="com.easy.xdo.EmployeDO">
      <id column="eid" property="id" />
      <result column="ename" property="name"/>
      <result column="age" property="age"/>
    </collection>
  </resultMap>
  <sql id="sqlBase">
     c.id,c.name,c.address,e.id as eid,e.name as ename,e.age 
  </sql>
  <sql id="WhereModelSql">
    <if test="where != null">
      <where>
        <if test="where.id != null and where.id != ''"> AND c.id=#{where.id} </if>
        <if test="where.name != null and where.name != ''"> AND c.name=#{where.name} </if>
        <if test="where.address != null and where.address != ''"> AND c.address=#{where.address} </if>
      </where>
    </if>
  </sql>
  <select id="selectList" resultMap="BaseResultMap" parameterType="com.easy.xdo.CompanyParam">
    select
    <include refid="sqlBase" />
    from company c left join employe e on  c.id=e.companyid  
    where c.id in (select page.id from (select id from company 
    <include refid="WhereModelSql" />  limit #{where.startrow},#{where.rows})
    page)
  </select>
  <select id="selectCount" resultType="java.lang.Integer" parameterType="com.easy.xdo.CompanyParam">
    select
    count(c.id)
    from company
    <include refid="WhereModelSql" />
  </select>
</mapper>

这里特殊说明一下in语句子语句中不能使用limit,但是孙语句中可以使用,很蛋疼所以多包了一层,sql语句这里大家可以根据自己的情况随意写,只要最后传参进去出来的数据准确就ok了


相关文章
|
6月前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
247 4
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
165 0
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
9月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
1490 1
Spring boot 使用mybatis generator 自动生成代码插件
|
10月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
946 15
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
298 0
|
Oracle 关系型数据库 Java
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
922 0
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
694 2