1.要点:
1)利用Spring的容器通过单例的方式管理SqlSessionFactory。2)Spring和MyBatis整合生成代理对象,使用sqlSessionFactory创建SqlSession
3)持久层的mapper需要由Spring进行管理。
2.代码结构
该章节是接续前面的例子继续学习,下面db.properties,log4j.properteis,User.java同前面章节相同,不在重复。需要加入MyBatis,MyBatis-Spring,Spring的jar包,这里lib中的内容省略。后面章节逐步给出其他文件的代码。├─config
│ │ db.properties //数据库配置文件
│ │ log4j.properties //log输出配置文件
│ │
│ ├─mybatis
│ │ sqlMapConfig.xml
│ │
│ └─spring
│ applicationContext.xml
│
├─lib
│ ...
│
├─src
│ ├─mapper
│ │ UserMapper.java
│ │ UserMapper.xml
│ │
│ └─po
│ User.java //用户对象
│
└─test
└─high
MapperTest.java
3.applicationContext.xml
配置Spring所需要的东西,可以看出1)利用Spring的容器通过单例的方式管理SqlSessionFactory。
2)持久层的mapper需要由Spring进行管理。
3)另外,SqlSession由Spring自动管理。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:mybatis-spring="http://mybatis.org/schema/mybatis-spring"
xsi:schemaLocation="http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd
http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring-1.2.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.2.xsd">
<context:property-placeholder location="classpath:db.properties"/>
<!-- c3p0连接池配置 -->
<bean id="c3p0DataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="user" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
<property name="driverClass" value="${jdbc.driver}"/>
<property name="jdbcUrl" value="${jdbc.url}"/>
<!-- 其他属性都使用默认值 -->
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="mybatis/sqlMapConfig.xml"></property>
<property name="dataSource" ref="c3p0DataSource"></property>
</bean>
<!-- 基本方法:根据Mapper接口生成单个代理对象,如果有多个Mapper需要创建多个Bean,这样比较麻烦
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="mapperInterface" value="mapper.UserMapper"/>
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
-->
<!-- 高级方法:指定扫描的包,从该包中扫描对应的mapper接口和xml配置文件,然后自动创建代理对象,并在spring中注入 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 配置需要扫描的包,这里不能使用通配符,若多个包,用逗号分开-->
<property name="basePackage" value="mapper,otherpackage"/>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
</beans>
4.sqlMapConfig.xml
这里配置一些MyBatis特殊的内容,比如别名,setting等。包映射等内容都移到Spring中的配置文件中完成。<?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="po"></package>
</typeAliases>
<!-- 指定需要扫描的映射接口所在的包 -->
<!-- 由于在Spring的配置文件中配置了MapperScannerConfigurer,此处就不需要再次配置扫描路径了。
<mappers>
<package name="mapper"/>
</mappers>
-->
</configuration>
5.UserMapper.xml和 UserMapper.java
跟之前的章节没啥区别。<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="mapper.UserMapper">
<select id="selectUserByName" parameterType="String" resultType="User">
select * from user where username = #{username};
</select>
</mapper>
package mapper;
import java.util.List;
import po.User;
public interface UserMapper {
List<User> selectUserByName(String username) throws Exception;
}
6.MapperTest.java
package high;
import java.util.List;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import mapper.UserMapper;
import po.User;
public class MapperTest {
public static void main(String[] args) throws Exception {
ApplicationContext ctx = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml");
//MapperScannerConfigurer自动扫描UserMapper接口,并将首字母小写的名字注册到Spring中。
UserMapper userMapper = (UserMapper) ctx.getBean("userMapper");
List<User> list = userMapper.selectUserByName("high");
System.out.println(list);
}
}
<完>