标注@transactional注解的方法,spring都会创建事务对象。关键在于spring的传播行为是否要建立新的连接。
我们常说的事务的传播行为,新建指的是新建一个connection。
非事务方式运行则是不创建connect;
重用,则用上一个。
新建,则会解绑connect的绑定,新建一个新的绑定。
关于事务同步器也是一样的。
非事务的,会将自己的属性数据放入。
重用,则不会放自己的,保持原来的。
新建,则会放入自己的。
但是加上这个注解,是一定交给spring管理事务的。只管提交有connect的
spring的事务和mybatis的事务。
mybatis的事务在sqlsessiontemplate中,自己提交;
但是注意:mybatis自己的事务是从连接池中获取的,是否自动提交是连接池决定的。
public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
SqlSession sqlSession = getSqlSession(
SqlSessionTemplate.this.sqlSessionFactory,
SqlSessionTemplate.this.executorType,
SqlSessionTemplate.this.exceptionTranslator);
try {
Object result = method.invoke(sqlSession, args);
if (!isSqlSessionTransactional(sqlSession, SqlSessionTemplate.this.sqlSessionFactory)) {
// force commit even on non-dirty sessions because some databases require
// // 如果不是自动提交,mybatis自己提交。
sqlSession.commit(true);
}
spring的事务,只要加@transactional注解,就给交给spring管理,无论是否有connect;
spring事务是手动提交的,但是提交只会提交有connect的。