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

发布于 2022-09-13 00:12:12 字数 985 浏览 27 评论 0

问题描述

我使用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条件里呢?感谢大佬指导。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

入怼 2022-09-20 00:12:12

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

祁梦 2022-09-20 00:12:12
new LambdaQueryChainWrapper<>(errorRegisterMapper)
                .eq(isNotBlank(errorRegisterDTO.getCreatorName()), ErrorRegisterEntity::getCreatorName, errorRegisterDTO.getCreatorName())

我写的这种,链式调用

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文