MyBatis 批量插入时拦截器失效的原因是什么?
一分耕耘,一分收获!既然打开了这篇文章,就坚持看下去吧!文中内容包含等等知识点…希望你能在阅读本文后,能真真实实学到知识或者帮你解决心中的疑惑,也欢迎大佬或者新人朋友们多留言评论,多给建议!谢谢!
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... }
今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注主机宝贝公众号,一起学习编程~