mybatis-plus 通过QueryWrapper进行多条件查询

标题mybatis-plus QueryWrapper

pojo:

@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
@TableName("m_goods")
@ApiModel(value="Goods对象", description="")
public class Goods implements Serializable {

    private static final long serialVersionUID = 1L;

    @ApiModelProperty(value = "序号主键")
    @TableId(value = "id", type = IdType.AUTO)
    private Integer id;

    @ApiModelProperty(value = "货物名称")
    private String goodsname;

    @ApiModelProperty(value = "货物价格")
    private Integer goodsprice;

    @ApiModelProperty(value = "货物数量")
    private Integer goodsnum;
}

Controller:

@ApiOperation(value = "根据条件查询商品")
    @PostMapping("/selectGoodsByCondition/{currentPage}/{pageSize}")
    public RespBean selectGoodsByCondition(@RequestBody Goods goods, @PathVariable("currentPage") Integer currentPage, @PathVariable("pageSize") Integer pageSize) {
        return goodsService.selectGoodsByCondition(goods, currentPage, pageSize);
    }

service:

@Override
    public RespBean selectGoodsByCondition(Goods goods,int currentPage, int pageSize) {
        QueryWrapper queryWrapper = isConditon(goods);
        PageHelper.startPage(currentPage, pageSize);
        List<Goods> goodsList = goodsMapper.selectGoodsByCondition(queryWrapper);
        return RespBean.success("查询成功", goodsList);
    }

构建查询条件:

/**
     * 查询条件构建
     * @param goods
     * @return
     */
    private QueryWrapper isConditon(Goods goods) {
        QueryWrapper queryWrapper = new QueryWrapper();
        if (goods != null) {
            if (!goods.getGoodsname().isEmpty()) {
                queryWrapper.like("goodsname", goods.getGoodsname());
            }
            if (goods.getGoodsnum() != null) {
                queryWrapper.eq("goodsnum", goods.getGoodsnum());
            }
            if (goods.getGoodsprice() != null) {
                queryWrapper.eq("goodsprice", goods.getGoodsprice());
            }
        }
        return queryWrapper;
    }

mapper:

public interface GoodsMapper extends BaseMapper<Goods> {

    List<Goods> selectGoodsByCondition(@Param(Constants.WRAPPER) Wrapper queryWrapper);
}

xml:

<select id="selectGoodsByCondition" resultType="com.xxx.pojo.Goods">
        select * from m_goods
        <if test="ew.emptyOfWhere == false">
            ${ew.customSqlSegment}
        </if>
    </select>

ew是mapper方法里的@Param(Constants.WRAPPER) Wrapper queryWrapper对象,Constants.WRAPPER的值就是ew。
首先判断ew.emptyOfWhere是否存在where条件,有的话再拼接上去。
ew.customSqlSegment是WHERE + sql语句。

  • 9
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Mybatis-Plus是一个优秀的ORM框架,它在MyBatis的基础上进行了功能扩展和优化,并且针对常见的业务场景提供了常用的解决方案。其中,QueryWrapperMybatis-Plus提供的查询构造器,支持多条件查询、排序、分页等功能。QueryWrapper多条件排序功能可以在查询时根据多个条件对结果进行排序。例如,我们可以通过QueryWrapper的order()方法来设置排序规则: QueryWrapper<User> queryWrapper = new QueryWrapper<>(); queryWrapper .eq("sex", 1) .ge("age", 18) .orderByAsc("age") //按照年龄升序排序 .orderByDesc("create_time"); //按照创建时间降序排序 在上述代码中,我们通过eq()方法设置性别为男性,通过ge()方法设置年龄大于等于18岁,然后通过orderByAsc()方法设置按照年龄升序排序,最后通过orderByDesc()方法设置按照创建时间降序排序。这样,最终查询结果会按照这两个条件的要求进行排序。 总之,Mybatis-PlusQueryWrapper多条件排序功能可以方便地实现排序需求,提高查询效率,为开发者提供了更加便捷的操作方式。 ### 回答2: mybatis-plus是一款基于mybatis的增强工具,可以简化mybatis的开发过程。mybatis-plus中提供了querywrapper多条件排序的功能,可以方便地对数据库进行多条件排序,实现数据的有序展示。 使用mybatis-plusquerywrapper进行多条件排序很简单,只需按照以下步骤进行操作: 1.创建querywrapper对象 在使用mybatis-plus查询时,需要通过querywrapper对象来添加查询条件。创建querywrapper对象非常简单,只需要调用QueryWrapper的静态方法就可以了: QueryWrapper<Entity> wrapper = new QueryWrapper<>(); 2.添加查询条件 除了添加查询条件之外,querywrapper还可以添加排序方式。多条件排序可以在wrapper对象中添加多个排序规则,每个排序规则可以指定一个字段和一个排序方向。例如,以下代码添加了两个排序规则,分别按照age和name字段进行升序排序: wrapper.orderByAsc("age", "name"); 3.执行查询操作 最后使用mybatis-plus提供的基本查询方法执行查询操作,例如selectList(),selectOne(),selectPage()等方法。 总之,mybatis-plus自带querywrapper多条件排序的功能可以大大简化复杂的多条件查询操作,提高了开发效率,也方便了数据的有序展示。在实际应用中,开发人员可以根据自己的需要灵活地使用这个功能。 ### 回答3: MyBatis-PlusMyBatis的一个增强工具包,它提供了许多实用的功能,使得MyBatis编写SQL语句更加简单方便。其中,QueryWrapperMyBatis-Plus提供的一个查询条件构建器,它可以方便地构建各种复杂的查询条件。 QueryWrapper提供了多种方法来构建查询条件,其中包括eq、ne、gt、lt、ge、le等基本的比较操作,也包括like、in、between等高级操作。同时,QueryWrapper还支持链式调用,可以方便地组合多个查询条件。 在多条件排序方面,QueryWrapper也提供了多种方法。其中,orderByAsc和orderByDesc方法可以分别按照升序和降序进行排序,而orderBy方法则可以按照自定义的排序规则进行排序。同时,orderBy方法还支持链式调用,可以方便地组合多个排序规则。 除了QueryWrapperMyBatis-Plus还提供了LambdaQueryWrapper,它可以使用Lambda表达式来构建查询条件,使得代码更加简洁易懂。LambdaQueryWrapper也支持多条件排序,使用方式与QueryWrapper类似。 总之,MyBatis-Plus提供了方便、实用的QueryWrapper查询条件构建器,提供了多种方法来构建查询条件和排序规则,使得MyBatis编写SQL语句更加简单高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值