java 多表分页_MyBatisPlus分页多表关联查询

本文介绍了在Java中使用MyBatisPlus进行多表分页查询的方法。通过在Mapper接口中自定义SQL注解,并利用${ew.customSqlSegment}拼接分页参数和查询条件。关键点在于保持自定义SQL的Pojo对象与BaseMapper中指定的Pojo对象一致,避免MybatisPlus找不到lambda缓存的问题。为了确保分页功能正常,多表关联查询的Mapper应单独创建。
摘要由CSDN通过智能技术生成

spring+spring mvc mybatis整合

113.5元

包邮

(需用券)

去购买 >

7c3c2fdaa721f1f38e1e8503f447af8f.png

BaseMapper提供的默认查询方法都是单表的,如果需要多表关联查询,同时还要支持分页,一个方案就是自己写Sql。

现在自己写Sql一般用的应该不是传统MyBatis那种写xml的老方法,而是通过在Mapper类里写注解来实现。

还需要解决的就是如何在自定义Sql语句中拼接MyBatisPlus的分页参数和查询条件。

示例如下:public interface GameQueryMapper extends BaseMapper {

String querySql = "SELECT a.*, b.org_id FROM t_game AS a LEFT JOIN t_game_game_org AS b ON b.game_id = a.id ";

String wrapperSql = "SELECT * from ( " + querySql + " ) AS q ${ew.customSqlSegment}";

/**

* 分页查询

*/

@Select(wrapperSql)

Page page(Page page, @Param("ew") Wrapper queryWrapper);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值