整合MyBatis
分析
最终需要管理的是Mapper实例
Mapper实例没有实现类,是通过SqlSession获得,但Sqlsession是线程不安全的,不能直接管理SqlSession,因为每个线程的SqlSession都是不一样的。
所以只能统一管理线程安全的SqlSessionFactory,通过他来获取SqlSsession,然后管理
mybatis对Spring支持的依赖中提供了注册SqlSessionFactory组件的工厂类
引入依赖
mybatis-spring、spring-jdbc、spring-tx
spring-xxx是官方的依赖,xxx-spring是第三方
<!--整合mybatis对Spring的支持-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.6</version>
</dependency>
<!--spring-tx通过jdbc的引入可以一起引入进来-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.15.RELEASE</version>
</dependency>
注册SqlSessionFactory组件
提供了一个工厂bean → FactoryBean
SqlSessionFactoryBean
public class SqlSessionFactoryBean implements FactoryBean<SqlSessionFactory>{
public SqlSessionFactory getObject() throws Exception {
if (this.sqlSessionFactory == null) {
this.afterPropertiesSet();
}
return this.sqlSessionFactory;
}
public Class<? extends SqlSessionFactory> getObjectType() {
return this.sqlSessionFactory == null ? SqlSessionFactory.class : this.sqlSessionFactory.getClass();
}
}
这个是已经提供好的,我们直接注册即可,不需要重新写
最终的返回值就是一个SqlSessionFactory
Mapper实例
找到所有的Mapper接口,将接口对应的代理实例注册为容器中的组件
我们需要提供的就是接口的位置
MapperScannerConfigurer 进行Mapper接口包目录管理的配置
注册DataSource组件需要引入druid依赖
<!--注册DataSource组件-->
<bean id="datasource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url"
value="jdbc:mysql://localhost:3306/practice?useSSL=false&characterEncoding=utf8&allowMultiQueries=true"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--可以提供datasource组件-->
<property name="dataSource" ref="datasource"/>
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--告知接口的位置-->
<property name="basePackage" value="com.cskaoyan.mapper"/>
<!--告知SqlSessionFactory-->