注意:Mybatis Plus 3.0.7 版本才开始用【自定义sql】+【QueryWrapper】,低版本不能使用,还是老实写SQL进行条件拼接
1、源码分析
在Wrapper
public abstract String getCustomSqlSegment();
在AbstractWrapper抽象类中进行了实现
@Override
public String getCustomSqlSegment() {
// MergeSegments 为 返回 合并 SQL 片段
MergeSegments expression = getexpression();
if (Objects.nonNull(expression)) {
NormalSegmentList normal = expression.getNormal();
String sqlSegment = getSqlSegment();
if (StringUtils.isNotEmpty(sqlSegment)) {
if (normal.isEmpty()) {
return sqlSegment;
} else {
return concatWhere(sqlSegment);
}
}
}
return StringUtils.EMPTY;
}
private String concatWhere(String sql) {
return Constants.WHERe + " " + sql;
}
2、案例讲解
2.1、dao
说明:
1、这里Dao层需要继承baseMapper,泛型指定为查询实体;
2、@Mapper,这个无过多说明;
3、最重要的是方法形参@Param("ew") QueryWrapper
@Mapper public interface ReseDao extends baseMapper{ IPage getReseList(IPage page, @Param("ew") QueryWrapper queryWrapper); }
2.2、xml
说明:
1、查询SQL写完后,不用写【WHERe】,在SQL后面加入【 ${ew.customSqlSegment}】,mybatisPlus会自动将查询添加进行拼接
2、为什么是ew:mybatisPlus 之前有EntityWrapper,在后面版本将EntityWrapper分化为了多个Wrapper,例如查询的时候,就是QueryWrapper,猜测可能之前通过ew引用地方太多,保留了使用ew
SELECT r.rese_id, r.rese_no, w.WORK_Name FROM t_s_db_rese r left join t_s_db_work w on r.WORK_id = w.WORK_id ${ew.customSqlSegment}
2.3、service
说明:
1、getPage(params, null, false): 方法用来拼接mybatis plus 分页组件(超链接进官方文档)
2、getWrapper(params):方法用来拼接 QueryWrapper 条件构造器(超链接进官方文档),
@Override public PageDatapage(Map params) { IPage page = reseDao.getReseList( // 调用 分页组件返回 IPage对象 getPage(params, null, false), // 调用 条件构造器 返回 Wrapper getWrapper(params) ); return getPageData(page, ReseDTO.class); } private QueryWrapper getWrapper(Map params) { QueryWrapper wrapper = new QueryWrapper<>(); wrapper.eq(params.get("xxx") != null, "w.WORK_Name", params.get("xxx")); return wrapper; } public IPage getPage(Map params, String defaultOrderField, boolean isAsc) { long curPage = 1L; long limit = 20L; if (params.get(Constant.PAGE) != null) { curPage = Long.parseLong((String) params.get(Constant.PAGE)); } if (params.get(Constant.LIMIT) != null) { limit = Long.parseLong((String) params.get(Constant.LIMIT)); } Page page = new Page(curPage, limit); if (isAsc) { page.setAsc(new String[]{defaultOrderField}); } else { page.setDesc(new String[]{defaultOrderField}); } return page; }
到此这篇关于基于Mybatis Plus实现多表分页查询的示例代码的文章就介绍到这了,更多相关Mybatis Plus多表分页查询内容请搜索考高分网以前的文章或继续浏览下面的相关文章希望大家以后多多支持考高分网!



