mybatis-plus如何实现动态查询?类似xml的if标签

问题描述

我使用mybatis和xml文件语法,实现了动态参数查询,如下所示。
image.png

但是现在切换到mybatis-plus后不知道怎么实现这种动态查询,目前的实现方法是这样。但是感觉很不好,不如if灵活方便,参数多了后很多if代码,难看。

image.png

图中的代码如下:

    @Override
    public Response getVideoCourse(Integer id){

        //动态设置查询条件
        HashMap<String, Object> map = new HashMap<>();
        System.out.println("dddddddddddddddddd"+id);
        if(id != null){
            map.put("id",id);
        }
//        如果有多个参数,就弄多个if,感觉不太好啊,很乱
//        if(other !=null){
//          map.put("other",other);
//        }
        List<VideoCourse> secondCategoryList = videoCourseMapper.selectByMap(map);
        Response data = new Response();
        data.setData(secondCategoryList);
        data.setMsg("成功");
        return  data;
    };
}

期望结果:

mybatis-plus如何实现类似xml的if标签,动态根据参数自动补充到where条件里呢?感谢大佬指导。

阅读 7.3k
3 个回答

通过条件构造器已经优化了结构,现在是这个样子了。
image.png

new LambdaQueryChainWrapper<>(errorRegisterMapper)
                .eq(isNotBlank(errorRegisterDTO.getCreatorName()), ErrorRegisterEntity::getCreatorName, errorRegisterDTO.getCreatorName())

我写的这种,链式调用

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题