Spring 整合 Mybatis 在開始使用 MyBatis Spring 之前,需要先熟悉 Spring 和 MyBatis 這兩個框架和有關它們的術語。 MyBatis Spring 需要以下版本: | MyBatis Spring | MyBatis | Spring 框架 | Spring ...
Spring 整合 Mybatis
在開始使用 MyBatis-Spring 之前,需要先熟悉 Spring 和 MyBatis 這兩個框架和有關它們的術語。
MyBatis-Spring 需要以下版本:
MyBatis-Spring | MyBatis | Spring 框架 | Spring Batch | Java |
---|---|---|---|---|
2.0 | 3.5+ | 5.0+ | 4.0+ | Java 8+ |
1.3 | 3.4+ | 3.2.2+ | 2.1+ | Java 6+ |
導入對應的 Maven 依賴
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.4.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.4.RELEASE</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.9.5</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.17</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.2</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.4</version>
</dependency>
</dependencies>
測試代碼如下,dao:
public interface UserMapper {
List<User> queryUsers();
}
對應的 xml 還是和 Mybatis一樣
<select id="queryUsers" resultType="user">
select * from user
</select>
pojo:
public class User {
private int id;
private String name;
private String pwd;
...
下麵創建一個 xml 使用 spring 的方式來創建 Mybatis所需要的對象
SqlSessionFactory
需要一個 DataSource
(數據源)。 這可以是任意的 DataSource
,只需要和配置其它 Spring 資料庫連接一樣配置它就可以了。上面導入了 spring-jdbc
這個依賴,所以這個地方就使用 spring 的 DriverManagerDataSource
來創建數據源
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis_db?serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
創建SqlSessionFactory
,並指定對應的 Mybatis 配置文件及 Mapper.xml
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="mybatis-config.xml"/>
<property name="mapperLocations" value="com/youzi/dao/*.xml"/>
</bean>
mybatis-config.xml 在這個地方沒有完全捨棄,可以用來配置 Mybatis 的相關設置及細節
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<typeAliases>
<package name="com.youzi.pojo"/>
</typeAliases>
</configuration>
整合之後使用 SqlSessionTemplate
的方式創建 sqlSession
SqlSessionTemplate
是 MyBatis-Spring 的核心。作為SqlSession
的一個實現,這意味著可以使用它無縫代替你代碼中已經在使用的SqlSession
。SqlSessionTemplate
是線程安全的,可以被多個 DAO 或映射器所共用使用。
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>
添加一個 Dao 實現類
public class UserMapperImpl implements UserMapper {
private SqlSessionTemplate sqlSession;
public void setSqlSession(SqlSessionTemplate sqlSession) {
this.sqlSession = sqlSession;
}
@Override
public List<User> queryUsers() {
return sqlSession.getMapper(UserMapper.class).queryUsers();
}
}
將 sqlSession
註入 UserMapperImpl
<bean id="userMapper" class="com.youzi.dao.UserMapperImpl">
<property name="sqlSession" ref="sqlSession"/>
</bean>
到此就可以直接使用 spring 獲取 userMapper
,完整的 xml 文件如下
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mybatis_db?serverTimezone=UTC"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="mybatis-config.xml"/>
<property name="mapperLocations" value="com/youzi/dao/*.xml"/>
</bean>
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>
<bean id="userMapper" class="com.youzi.dao.UserMapperImpl">
<property name="sqlSession" ref="sqlSession"/>
</bean>
</beans>
另一種方式:
使用 SqlSessionDaoSupport
創建 SqlSession
,SqlSessionDaoSupport
是一個抽象的支持類,用來為你提供 SqlSession
。調用 getSqlSession()
方法你會得到一個 SqlSessionTemplate
,之後可以用於執行 SQL 方法
public class UserMapperImpl extends SqlSessionDaoSupport implements UserMapper {
@Override
public List<User> getUsers() {
return getSqlSession().getMapper(UserMapper.class).getUsers();
}
}
<bean id="userMapper" class="com.youzi.dao.UserMapperImpl">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
事務
聲明式事務配置--使用 aop 的方式 Spring-tx
模塊實現事務管理
添加tx名字空間
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<tx:attributes>
<tx:method name="*" propagation="REQUIRED"/>
</tx:attributes>
</tx:advice>
<aop:config>
<aop:pointcut id="txPointCut" expression="execution(* com.youzi.dao.*.*(..))"/>
<aop:advisor advice-ref="txAdvice" pointcut-ref="txPointCut"/>
</aop:config>
事務傳播行為類型 | 說明 |
---|---|
REQUIRED | 如果當前沒有事務,就新建一個事務,如果已經存在一個事務中,加入到這個事務中。這是最常見的選擇。 |
SUPPORTS | 支持當前事務,如果當前沒有事務,就以非事務方式執行。 |
MANDATORY | 使用當前的事務,如果當前沒有事務,就拋出異常。 |
REQUIRES_NEW | 新建事務,如果當前存在事務,把當前事務掛起。 |
NOT_SUPPORTED | 以非事務方式執行操作,如果當前存在事務,就把當前事務掛起。 |
NEVER | 以非事務方式執行,如果當前存在事務,則拋出異常。 |
NESTED | 如果當前存在事務,則在嵌套事務內執行。如果當前沒有事務,則執行與PROPAGATION_REQUIRED類 似的操作。 |