簡體   English   中英

如何使用mybatis-string在一個會話中執行多個sql語句

[英]How to execute several sql-statements in one session with mybatis-string

我正在使用 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 語句,直到所有方法/語句都被執行后才會關閉?

謝謝和問候。

似乎事務沒有正確划分,並且使用了默認行為(對映射器的一次調用 - 一次事務 - 一個 mybatis 會話)。

spring-mybatis中 session 綁定到 spring 事務。 如果事務沒有被划分,那么每次調用 mybatis mapper 方法都會創建一個事務(因此 mybatis SqlSession )。

為了改變這一點,您需要正確配置 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);
  }

}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM