若依3.6.0使用Mybatis-plus分页失效以及完美替换Pagehelper【已解决】

一、前言

小编最近在经历后端框架的迁移,虽然不是小编来做,但是有个分页的情况让小编和一个同事去搞。
说一下小编这边的需求:
原来框架使用Mybatis-plus进行分页,要更换的新框架若依是使用Pagehelper。所以现在需求让我们把若依的干掉,使用Mybatis-plusMybatis-plus的生态还是挺好的,方便,最重要的是和原来的框架一样,不需要更改。
存在问题:需要把若依以前的分页全部改成Mybatis-plus的分页,那我们就按个换喽,谁让咱们喜欢搬砖!

先说一下问题出现的原因:
Mybatis和Mybatis-plus存在冲突,Pagehelper依赖于Mybatis,所以冲突了!!

解决方案:
PagehelperMybatis的依赖,然后一点点的改若依一些基本配置的分页就好,最后在加上Mybatis-plus的分页插件配置!最最重要的是要扫描到写的分页插件,不然不生效!

二、删依赖

1. 删除根目录的依赖

<!-- Mybatis 依赖配置 -->
<dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>${spring-boot.mybatis}</version>
</dependency>

<!-- pagehelper 分页插件 -->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>${pagehelper.boot.version}</version>
</dependency>
<spring-boot.mybatis>2.2.2</spring-boot.mybatis>

2. 根目录添加依赖

<!--   mybatis-plus     -->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>${spring-boot.mybatis-plus}</version>
</dependency>
<spring-boot.mybatis-plus>3.5.1</spring-boot.mybatis-plus>

3. ruoyi-common-core模块删除依赖

<!-- Pagehelper -->
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
</dependency>

三、修改文件

1. 注释PageUtils

整个类全部注释!

/**
 * 分页工具类
 * 
 * @author ruoyi
 */
public class PageUtils extends PageHelper{}

2. 注释BaseController分页方法

/**
 * 设置请求分页数据
 */
protected void startPage()
{
    PageUtils.startPage();
}

/**
 * 清理分页的线程变量
 */
protected void clearPage()
{
    PageUtils.clearPage();
}

/**
 * 响应请求分页数据
 */
@SuppressWarnings({ "rawtypes", "unchecked" })
protected TableDataInfo getDataTable(List<?> list)
{
    TableDataInfo rspData = new TableDataInfo();
    rspData.setCode(HttpStatus.SUCCESS);
    rspData.setRows(list);
    rspData.setMsg("查询成功");
    rspData.setTotal(new PageInfo(list).getTotal());
    return rspData;
}

四、配置Mybatis-plus分页

1. 在ruoyi-common-core中新建配置类

@Configuration
public class MybatisPlusConfig {

    /**
     * 新的分页插件,一缓和二缓遵循mybatis的规则,需要设置 MybatisConfiguration#useDeprecatedExecutor = false 避免缓存出现问题(该属性会在旧插件移除后一同移除)
     */
    @Bean
    public MybatisPlusInterceptor mybatisPlusInterceptor() {
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return interceptor;
    }

}

在这里插入图片描述

2. 配置上可以扫描的

我们发现在core中已经给了我们提示,他配置了一个,我们只需要把我们刚刚写的配置类加上去,就可以扫描到这配置,然后生效了!!

不配置不生效(切记切记)

我们找到所在位置,添加上全路径即可,这里我们对若依的架构修改了名称,也就是若依的core包下的!

在这里插入图片描述

五、修改ruoyi-modules-system

我们的宗旨是不影响之前的使用,需要我们新写一个分页,因为他们的export接口都使用了原来的分页,虽然分页没了,但是只要不调用还是不会报错的!
我们以一个controller的改造为例:

1. SysConfigController改造

原来的方法:

/**
 * 获取参数配置列表
 */
@RequiresPermissions("system:config:list")
@GetMapping("/list")
public TableDataInfo list(SysConfig config)
{
    startPage();
    List<SysConfig> list = configService.selectConfigList(config);
    return getDataTable(list);
}

修改后的方法:
这里统一返回值我是使用我们以前架构的,大家也可以使用若依自带的AjaxResult,只需要添加上Page即可,原来的方法我们不动,重新写一个两个参数的方法。

/**
 * 获取参数配置列表
 */
@RequiresPermissions("system:config:list")
@GetMapping("/list")
public R list(Page page, SysConfig config) {
    return R.ok(configService.selectConfigList(page, config));
}

2. ISysConfigService新增分页方法

/**
 * 新分页
 * @param page
 * @param config
 * @return
 */
Page<SysConfig> selectConfigList(Page page,SysConfig config);

3. SysConfigServiceImpl新增分页实现方法

@Override
public Page<SysConfig> selectConfigList(Page page, SysConfig config) {
    return configMapper.selectConfigList(page,config);
}

4. SysConfigMapper新增分页接口

/**
 * 新分页
 * @param page
 * @param config
 * @return
 */
Page<SysConfig> selectConfigList(Page page,@Param("config") SysConfig config);

5. 总结

这样依次对ruoyi-modules-system项目进行修改,还有一些jobgen,不要和不用的就注释掉,只要不报错,原来的项目分页就可以展示出来,原来不改造之前是total和pages都是0,改造后恢复正常。

总的来说就是删依赖,加依赖,注释一些不要的,添加一个新的分页方法即可,都是搬砖的活,哈哈!!

如果解决了你的问题,还不赶紧一键三连来支持一波小编!!谢谢大家喽~~

六、补充

这样之后我们发现system项目中的分页是有问题,是因为xml文件里没有指定对象.属性。于是把xml的一个例子修改了,现在分享给大家:

<select id="selectDeptList" resultMap="SysDeptResult">
    <include refid="selectDeptVo"/>
    where d.del_flag = '0'
    <if test="dept.deptId != null and dept.deptId != 0">
        AND dept_id = #{dept.deptId}
    </if>
    <if test="dept.parentId != null and dept.parentId != 0">
        AND parent_id = #{dept.parentId}
    </if>
    <if test="dept.deptName != null and dept.deptName != ''">
        AND dept_name like concat('%', #{dept.deptName}, '%')
    </if>
    <if test="dept.status != null and dept.status != ''">
        AND status = #{dept.status}
    </if>
    <!-- 数据范围过滤 -->
    ${dept.params.dataScope}
    order by d.parent_id, d.order_num
</select>

有缘人才可以看得到的哦!!!

点击访问!小编自己的网站,里面也是有很多好的文章哦!

  • 6
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
以下是一个示例代码,其中包括了Spring Boot整合MyBatis-Plus进行分页查询的实现以及前端页面的展示。 后端代码: ```java @RestController @RequestMapping("/user") public class UserController { @Autowired private UserService userService; /** * 分页查询用户列表 */ @GetMapping("/list") public ResultVo list(Page<User> page) { // 查询条件封装在 QueryWrapper 对象中 QueryWrapper<User> wrapper = new QueryWrapper<>(); wrapper.eq("status", 1); // 查询状态为1的用户 // 执行分页查询 userService.page(page, wrapper); // 将查询结果封装为 ResultVo 对象返回给前端 return ResultVo.success(page); } } ``` 前端代码: ```html <table> <thead> <tr> <th>用户名</th> <th>年龄</th> <th>手机号</th> </tr> </thead> <tbody id="user_list"></tbody> </table> <div id="pagination"></div> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/twbs-pagination/1.4.2/jquery.twbsPagination.min.js"></script> <script> $(function() { // 初始化分页组件 $('#pagination').twbsPagination({ totalPages: 1, visiblePages: 5, onPageClick: function(event, page) { // 发起分页查询请求 $.get('/user/list', { page: page }, function(res) { if (res.code === 200) { // 渲染查询结果到页面 var html = ''; res.data.records.forEach(function(user) { html += '<tr>'; html += '<td>' + user.username + '</td>'; html += '<td>' + user.age + '</td>'; html += '<td>' + user.mobile + '</td>'; html += '</tr>'; }); $('#user_list').html(html); // 更新分页组件 $('#pagination').twbsPagination('destroy'); $('#pagination').twbsPagination({ totalPages: res.data.pages, visiblePages: 5, startPage: res.data.current, first: '首页', prev: '上一页', next: '下一页', last: '末页', onPageClick: function(event, page) { // 发起分页查询请求 $.get('/user/list', { page: page }, function(res) { if (res.code === 200) { // 渲染查询结果到页面 var html = ''; res.data.records.forEach(function(user) { html += '<tr>'; html += '<td>' + user.username + '</td>'; html += '<td>' + user.age + '</td>'; html += '<td>' + user.mobile + '</td>'; html += '</tr>'; }); $('#user_list').html(html); } }); } }); } }); } }); }); </script> ``` 在上面的代码中,我们使用MyBatis-Plus 提供的 `Page` 类来进行分页查询,具体的查询条件通过 `QueryWrapper` 对象进行封装。在前端页面中,我们使用了 `jquery.twbsPagination` 插件来实现分页组件,并通过 AJAX 发起分页查询请求,并将查询结果渲染到页面上。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

掉发的小王

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值