温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MybatisPlus EntityWrapper怎么自定义SQL

发布时间:2022-03-22 13:35:31 来源:亿速云 阅读:277 作者:小新 栏目:开发技术

这篇文章主要介绍MybatisPlus EntityWrapper怎么自定义SQL,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

    EntityWrapper自定义SQL

    在mybatis plus中根据条件构造器,构建SQL查询是很方便的,使用条件构造器可以替代我们写SQL。下面我们看几个例子。

    第一种

    使用T selectOne(Wrapper<T> wrapper);我们只需要传递入我们创建一个EntityWrapper()并将条件拼接好就可以。

    例如new EntityWrapper().eq("id","1")就是查询id等于1的这条数据。这里不仅仅支持eq(),还有like,not like ,group by等,差不多在SQL中需要的这里都有。

    第二种

    在单表查询的时候我们需要自定义列的时候则使用setSqlSelect方法,具体如下:

    /**此格式的意思为requireParam传参了才创建where条件,请按照此格式撰写代码
    *Object为你的单表实体类
    *requireParam为入参实体类
    *EntityWrapper<Object> ew = new EntityWrapper<Object>(requireParam);是为了让构造where条件
    *我在前面给requireParam的state属性设置了值为1,所以这里会自动拼接上where条件,如果不需要的话则可不传requireParam
    *
    *
    **/
                EntityWrapper<Object> ew = new EntityWrapper<Object>(requireParam);
                /**设置需要查询的列名**/
                ew.setSqlSelect("id,resource_id,user_id,username,content,createtime,parent_id," +
                        " path,type,like_count")
                        /**排序方式**/
                        .orderBy(false,"path",false);

    同第一种情况一样,后面可以继续拼接各种条件。

    第三种

    EntityWrapper()拼接where条件,这个其实在第二种情况中已经讲了,就是根据我们创建EntityWrapper的时候有没有入参来做。

    到目前我们只用到了这些,以后遇到了我会继续更新。

    MybatisPlus自定义sql查询

    public void reconciliationForConfirmOne(Integer Id, Integer payoffType) {
        List<FinanceReconciliationEntity> frList = financeReconciliationService.selectList(
                new EntityWrapper<FinanceReconciliationEntity>()
                        .eq("payoff_id", Id)
                        .eq("payoff_type", payoffType)
                        .where("(reconciliation_status <> 1 OR reconciliation_status IS NULL)")
        );
        for (FinanceReconciliationEntity fr : frList) {
            fr.setReconciliationStatus(1);
        }
        if (frList != null && frList.size() > 0) {
            financeReconciliationService.updateBatchById(frList);
        }
    }

    以上是“MybatisPlus EntityWrapper怎么自定义SQL”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI