Кажется, что транзакции не разграничены должным образом и используется поведение по умолчанию (один вызов mapper - одна транзакция - один сеанс mybatis).
В spring-mybatis
сеанс привязан к весенней транзакции.Если транзакции не разграничены, то транзакция создается (и, следовательно, mybatis SqlSession
) для каждого вызова метода mybatis mapper.
Чтобы изменить это, вам необходимо правильно настроить spring так, чтобы:
- транзакций можно использовать на всех
- конфигурировать границы транзакций, поэтому вызовы к базе данных должны выполняться за одну транзакцию
Существует множество способов настройки транзакций дляподробности см. документация .Здесь я покажу простой способ, который использует конфигурацию xml.
Во-первых, добавьте диспетчер транзакций в конфигурацию Spring:
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
Затем необходимо указать границы транзакций.Простой способ - использовать декларативное управление транзакциями:
Добавить это в конфигурацию Spring
<tx:annotation-driven/>
И затем использовать @Transactional
аннотацию для методов, которые должны выполняться транзакционно:
@Service
class SomeService {
@Autowired MyMapper mapper;
@Transactional
SomeResult someMethod () {
Piece1 piece1 = mapper.getSome();
Piece2 piece2 = mapper.getMore();
SomeResult result = SomeResult(piece1, piece2);
}
}