MyBatis-Plus自定义sql注入器

6 篇文章 0 订阅
4 篇文章 0 订阅

一、前言

在日常开发过程中,我们可能会发现 MyBatis-Plus 提供的那些自带的 sql 语句无法满足我们的开发需求,想要加一些自定义的 sql,而且要应用于所有的 Mapper 上,需要怎么实现呢?

二、MyBatis-Plus自定义sql注入器功能实现

官方文档地址:https://baomidou.com/pages/42ea4a/

2.1、编写自定义sql类

编写一个自定义 sql 类,要继承 AbstractMethod 类,然后实现其 injectMappedStatement 方法来定义 sql 语句并加入到 MappedStatement 里,也可以重写 getMethod 方法来修改方法名。

ps:这里以 LogicDeleteByIdWithFill (逻辑删除并做自动填充)举例,这个是 MyBatis-Plus 自己做的扩展,如果需要自己定义 sql,仿照这个或者DefaultSqlInjector 类里的各个默认方法写就可以了。

image-20230726144224910

其实如果自己在 xml 里写 sql 的话,最终也是添加到 MappedStatement 里,这里其实就是模拟了这个操作,而且每个 Mapper 都会走这段代码,看似每个 Mapper 的 xml 里没有这些方法,但其实都存在。

2.2、将自定义sql添加到BaseMapper中

这里建议写一个自己的 BaseMapper 继承自 MyBatis-Plus 的 BaseMapper,然后所有的业务 Mapper 都继承自己的 BaseMapper

public interface MyBaseMapper<T> extends BaseMapper<T> {

    /**
     * 带自动填充的删除
     *
     * @param entity
     * @return
     */
    int deleteByIdWithFill(T entity);
}

注意,这里的方法名要与2.1中 getMethod 方法返回的方法名一致。

2.3、编写自己的sql注入器

编写一个自己的 sql 注入器,继承 DefaultSqlInjector ,实现其 getMethodList 方法,将之前写的自定义 sql 类加入其中

@Component
public class MySqlInjector extends DefaultSqlInjector {

    @Override
    public List<AbstractMethod> getMethodList(Class<?> mapperClass) {
        List<AbstractMethod> methodList = super.getMethodList(mapperClass);
        methodList.add(new LogicDeleteByIdWithFill());
        return methodList;
    }
}

这样就会在原本的方法基础上增加我们自定义的这个方法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

每天进步亿点点的小码农

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值