Mybatis-plus手写SQL如何使用条件构造器和分页

Mybatis-plus手写SQL如何使用条件构造器和分页插件

前言:在使用mybatis-plus过程中,使用条件构造器和分页插件非常效率的提升开发速度,但有些业务需要使用连表查询,此时还想使用条件构造器和使用分页时应该如何操作呢?

Mapper接口层

java 复制代码
public interface BookOrderMapper extends BaseMapperPlus<BookOrder, BookOrderVo> {
    List<OrderApp> getOrderAppList(@Param("orderState") String orderState);

    Page<OrderApp> getOrderAppPage(Page<OrderApp> page, @Param(Constants.WRAPPER) Wrapper<OrderApp> wrapper);
}

xml层

xml 复制代码
<select id="getOrderAppPage" resultMap="orderApp">
        SELECT *
        FROM
        book_order t2
        LEFT JOIN book_order_detail t1 ON t1.order_id = t2.order_id and t1.del_flag = 0
        LEFT JOIN t_sku t3 ON t1.sku_id = t3.id
        LEFT JOIN books t4 ON t4.book_id = t3.book_id
        ${ew.customSqlSegment}
    </select>

调用

java 复制代码
        // 查询构造器,如果是连表查询的话建议使用QueryWrapper,这样可以手动指定条件列名 例如:t2.xxx
        boolean b = !StringUtils.equals(orderState, "0");
        QueryWrapper<OrderApp> queryWrapper = Wrappers.query(OrderApp.class);
        queryWrapper.eq("t2.user_id",userId);
        queryWrapper.eq(b,"t2.order_state",orderState);
        queryWrapper.eq("t2.del_flag","0");
        queryWrapper.orderByDesc("t2.create_time");

        // 调用sql
        Page<OrderApp> orderAppPage = bookOrderMapper.getOrderAppPage(new Page<>(page, pageSize), queryWrapper);

分页插件:

在返回结果使用Page< T >即可

条件构造器:

  1. mapper参数中添加 @Param(Constants.WRAPPER) Wrapper< T > wrapper (实参传递QuerWrapper或LamdaQuerWrapper都可以)
  2. 在sql的最后方添加 sql片段: {ew.customSqlSegment} (带**where** 关键字) 或 {ew.sqlSegment}(不带where关键字)
相关推荐
好奇的菜鸟3 分钟前
MyBatis-Plus 中 QueryWrapper 的 Limit 实现
java·tomcat·mybatis
l_tian_tian_15 分钟前
SpringCloud——MybatisPlus
java·spring boot·mybatis
petunsecn16 分钟前
MySql添加非空字段时的“伪空”问题
数据库·mysql
小传blog32 分钟前
解决PLSQL工具连接Oracle后无法使用ODBC导入器问题
数据库·oracle
小L爱科研39 分钟前
7.6/Q1,GBD数据库最新文章解读
数据库·数据分析·逻辑回归·线性回归·健康医疗
Code哈哈笑44 分钟前
【基于SpringBoot的图书购买系统】深度讲解 分页查询用户信息,分析前后端交互的原理
java·数据库·spring boot·后端·spring·交互
kingwebo'sZone1 小时前
sqlite的拼接字段的方法(sqlite没有convert函数)
java·数据库·sqlite
珹洺2 小时前
计算机操作系统(十二)详细讲解调计算机操作系统调度算法与多处理机调度
android·java·数据库
simple_whu2 小时前
使用SQLite Expert个人版VACUUM功能修复数据库
数据库·sqlite
为美好的生活献上中指2 小时前
java每日精进 5.20【MyBatis 联表&分页查询】
java·tomcat·mybatis·mpj