Как выполнить несколько SQL-операторов в одной сессии с mybatis-string - PullRequest
1 голос
/ 12 апреля 2019

Я настраиваю приложение с помощью mybatis-spring, которое должно выполнить несколько SQL-операторов (в основном выбирает) и вывести результат на консоль.

Мой applicationContext.xml выглядит так:

    <context:property-placeholder location="classpath:application.properties"/>

    <!-- BEANS -->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="${spring.datasource.driverClassName}"/>
        <property name="url" value="${spring.datasource.url}"/>
        <property name="username" value="${spring.datasource.username}"/>
        <property name="password" value="${spring.datasource.password}"/>
    </bean>

    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <property name="mapperLocations" value="classpath:sql_mapper.xml"/>
    </bean>

    <bean id="organisationMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
        <property name="mapperInterface" value="mapper.OrganisationMapper" />
        <property name="sqlSessionFactory" ref="sqlSessionFactory" />
    </bean>

Я заметил, что всякий раз, когда я выполняю SQL-оператор, сеанс создается только для этого оператора и закрывается сразу после выполнения.

Есть ли способ выполнить несколько SQL-операторов только в одномсеанс, который закрывается не до тех пор, пока не будут выполнены все методы / операторы?

Спасибо и привет.

1 Ответ

1 голос
/ 15 апреля 2019

Кажется, что транзакции не разграничены должным образом и используется поведение по умолчанию (один вызов mapper - одна транзакция - один сеанс mybatis).

В spring-mybatis сеанс привязан к весенней транзакции.Если транзакции не разграничены, то транзакция создается (и, следовательно, mybatis SqlSession) для каждого вызова метода mybatis mapper.

Чтобы изменить это, вам необходимо правильно настроить spring так, чтобы:

  1. транзакций можно использовать на всех
  2. конфигурировать границы транзакций, поэтому вызовы к базе данных должны выполняться за одну транзакцию

Существует множество способов настройки транзакций дляподробности см. документация .Здесь я покажу простой способ, который использует конфигурацию 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);
  }

}
...