mybits-plus中一个查询中同时使用多个queryWrapper实现

一、常规情况

        一般来说,写查询方式的时候通常只会绑定一个where语句,也就是一个QueryWrapper,如下:

Integer queryCreaterScoredNum(@Param(Constants.WRAPPER) QueryWrapper<Object> query);

二、特殊情况

        在做复杂统计功能的时候,存在很多join或者说select嵌套select,内层的select被当做表来使用,所以一个复杂的sql语句中就会存在多个完全不相关的where语句,这时候就需要使用到多个QueryWrapper了。比如:

// 在Dao或者mapper中传入多个queryWrapper
@Select("SELECT " +
    " COUNT(DISTINCT a.id) " +
    " FROM " +
    " oa_news_article AS a " +
    " LEFT JOIN oa_news_score AS b ON a.id = b.art_id " +
    " ${ew.customSqlSegment} 或者 ${query1Str} 或者 ${query2Str}" )
IPage<UserScoreDto> queryUserPageList(IPage<Score> page,
  @Param(Constants.WRAPPER) QueryWrapper<Object> query,
  @Param("query1") QueryWrapper<Object> query1,
  @Param("query2") QueryWrapper<Object> query2,
  @Param("query1Str") String query1Str,
  @Param("query2Str") String query2Str
);


// 调用的地方替换一下其他query的ew前缀
QueryWrapper<Object> query1 = queryWrapper.clone();
query1.eq("a.type", 1);
String query1Str = query1.getCustomSqlSegment().replaceAll("ew", "query1");
QueryWrapper<Object> query2 = queryWrapper.clone();
query2.eq("a.type", 2);
String query2Str = query2.getCustomSqlSegment().replaceAll("ew", "query2");
IPage<UserScoreDto> returnPageData = getBaseMapper().queryUserPageList(param.getPage(),
        queryWrapper,
        query1, query2
        query1Str, query2Str
);

三、原理解释

        对于常规使用一个QueryWrapper用法,包含了两个部分,一个参数:@Param(Constants.WRAPPER) QueryWrapper,另一个是sql语句中的解析占位:${ew.customSqlSegment}。

        重点在于@Param(Constants.WRAPPER)中的Constants.WRAPPER(源码为“ew”),其实mybits-plus是把query拼装为sql语句,参数用占位符代替,比如:ew.status=xxx这样表述。那么我们只需要在使用多个QueryWrapper的时候,把前面这个ew替换成为我们自己@Param中参数名,并且把替换好的sql传进去,同时把对应的queryMap也传进去保证query1.xxx可以找到对应就可以了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值