Mybatis中插入方法返回数字的示例分析

  介绍

这篇文章主要介绍了Mybatis中插入方法返回数字的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获、下面让小编带着大家一起了解一下。

前言:前几天在做项目演示的时候,发现有一个很奇怪的现象,就是Mybatis发现更新和插入返回值一直为“-2147482646”,无论怎么改,这个值一直不变…是在摸不着头脑,百度和谷歌了一下,有这样的说法原来是由defaultExecutorType设置引起的,如果设置为批处理,更新返回值就会丢失。

如果使用批处理执行程序,更新数量正在流失。

操作:也就是说在春天的配置文件中,只要把constructor-arg中的executorType改为简单(以前的值是批处理就会引发这个问题)或者直接注释掉就可以了

& lt; bean  id=皊qlSessionTemplate",类=皁rg.mybatis.spring.SqlSessionTemplate"比;   ,,,& lt; constructor-arg  name=皊qlSessionFactory", ref=皊qlSessionFactory"祝辞& lt;/constructor-arg>   ,,,& lt; !——,执行类型,——比;   ,,,& lt; constructor-arg  name=癳xecutorType",价值=https://www.yisu.com/zixun/"简单">   

这么一改果然好使,但是为啥会返回这个奇怪的数字呢?背后有啥原因,本篇博客就来研究一下为什么会返回这个数字,打开我们的想法,又到了跟踪源码的时候了,走起:

1:打开配置文件中的变量,看到SqlSessionTemplate这个类有个构造参数类型ExecutorType了,也就是我们配置的值,当它为批处理的时候又会怎么样呢?

 Mybatis中插入方法返回数字的示例分析

2: ExecutorType的参数,打开这个类发现它是个枚举类型,也就是说它仅仅只有3种配置的值,简单,简历,批处理,在配置文件中我们也只能配这三种其中的一个

 Mybatis中插入方法返回数字的示例分析

3:程序执行,可见最终操作的是SqlSession的插入方法,我们就来打开这个方法的源码:

Reader  config =, Resources.getResourceAsReader (“conf.xml");   SqlSessionFactory  sessionFactory =, new  SqlSessionFactoryBuilder () .build(配置);   SqlSession  SqlSession =, sessionFactory.openSession ();   String  sql =,“com.mlxs.mybatis.test.userMapper.insertUser";   int  res=, sqlSession.insert (sql,,“1“);//

4: sqlSession.insert()方法:

public  interface  SqlSession  extends  Closeable  {   ,int 插入(String  var1);   ,int 插入(String  var1, Object  var2);   }

SqlSession是一个接口,里面有插入方法,我们再来看一下这个接口的实现类:

 Mybatis中插入方法返回数字的示例分析

一般在源码中,如果没有特殊配置肯定是采用的默认的设置,我们就来看看DefaultSqlSession的源码:

 Mybatis中插入方法返回数字的示例分析

再找。插入方法:

 Mybatis中插入方法返回数字的示例分析

可以看的到,它调用的是这个。更新方法,再来找一个更新方法:

 Mybatis中插入方法返回数字的示例分析

看到本质上它调用的是遗嘱执行人的更新方法,我们再点进去看更新方法:

 Mybatis中插入方法返回数字的示例分析

可以看到它是一个接口,那么肯定要找实现类了:

 Mybatis中插入方法返回数字的示例分析

这里就可以看出端倪了,如果没有配置缓存的话,肯定用的是BaseExecutor,那么我们在配置文件中配置的是批处理,毋庸置疑它肯定是选择BatchExecutor这个类中更新的方法了:

 Mybatis中插入方法返回数字的示例分析

千呼万唤始出来,这个奇怪的数字原来在这里出来的,其中可以看到它是固定返回的,没有任何判断逻辑……这样就证明了一点,只要你的插入方法在配置文件中配置的是一批,那么它肯定返回这个值!

Mybatis中插入方法返回数字的示例分析