mybatis批量插入时拦截器失效的原因
使用mybatis时,批量插入数据可能会导致拦截器失效。这是因为在执行批量插入时,mybatis会使用statementhandler执行更新,而不是executor。默认情况下,拦截器只拦截executor上的update方法,因此不会被触发。
解决方法
要解决这个问题,需要在@intercepts注解中添加statementhandler.update方法的签名,以确保拦截器可以拦截批量插入。修改后的拦截器如下:
@Component @Intercepts({ @Signature(type = Executor.class,method = "update",args = {MappedStatement.class, Object.class}), @Signature(type = StatementHandler.class,method = "update",args = {Statement.class}) }) public class MyBatisAutoFillPlugin implements Interceptor { // some code... }
登录后复制