如何使用 mybatis-string 在一个会话中执行多个 sql-statements
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 语句,直到所有 methods/statements 都执行完毕后才会自行关闭?
谢谢和问候。
似乎事务没有正确划分,使用了默认行为(一次调用 mapper - 一次事务 - 一次 mybatis 会话)。
在 spring-mybatis
会话绑定到 spring 事务。如果事务没有被划分,那么每次调用 mybatis 映射器方法都会创建一个事务(因此 mybatis SqlSession
)。
为了改变这一点,您需要正确配置 spring 以便:
- 完全可以使用交易
- 配置事务边界,即应该在一个事务中执行对数据库的调用
配置事务的方法有很多种,详情见documentation。我将在这里展示使用 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);
}
}
我正在使用 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 语句,直到所有 methods/statements 都执行完毕后才会自行关闭?
谢谢和问候。
似乎事务没有正确划分,使用了默认行为(一次调用 mapper - 一次事务 - 一次 mybatis 会话)。
在 spring-mybatis
会话绑定到 spring 事务。如果事务没有被划分,那么每次调用 mybatis 映射器方法都会创建一个事务(因此 mybatis SqlSession
)。
为了改变这一点,您需要正确配置 spring 以便:
- 完全可以使用交易
- 配置事务边界,即应该在一个事务中执行对数据库的调用
配置事务的方法有很多种,详情见documentation。我将在这里展示使用 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);
}
}