MyBatis之MyBatis-Spring整合之简化配置
1、扫描式加载SQL映射文件
修改applicationContext.xml为SqlSessionFactoryBean设置mapperLocations属性
<!-- 配置session工厂 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="configLocation" value="classpath:myBatis-config.xml" />
<!-- 配置扫描式加载SQL映射文件 -->
<property name="mapperLocations" value="classpath:cn/itcast/entity/*.xml"/>
</bean>
2、MapperScannerConfigurer简化配置
1) 在spring配置文件中添加MapperScannerConfigurer 配置并去掉所有的Dao接口实现类配置
<!-- 配置 转换器,对于在basePackage设置的包(包括子包)下的接口类的全类名和在Mapper.xml文件中定义过的命名空间一致,
spring将会生成对应的代理对象(在调用 的地方通过@Autowired方式将可以注入接口实例)-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
<property name="basePackage" value="cn.itcast.dao"/>
</bean>
<!-- DAO层部门信息表的数据操作对象,上面如果配置MapperScannerConfigurer转换器,DAO接口将不再使用实现类 -->
<!--
<bean id="deptDao" class="cn.itcast.dao.impl.DeptDaoImpl" >
<property name="sqlSessionTemplate" ref="sqlSessionTemplate"/>
</bean>
-->
<!-- 业务层部门信息业务处理对象 -->
<bean id="deptService" class="cn.itcast.service.impl.DeptServiceImpl">
<!-- 上面如果配置MapperScannerConfigurer转换器,DAO接口将不再使用实现类注入 -->
<!-- <property name="deptDao" ref="deptDao"/> -->
</bean>
2) 检查或修改DeptMapper.xml文件:命名空间+id和接口+方法名 一致
<?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">
<!-- 这时的命名空间就需要和dao接口类全类名一致了 -->
<mapper namespace="cn.itcast.dao.DeptDao">
<!-- 表字段和对应实体属性命名一致时可以不配置 -->
<resultMap id="deptResultMap" type="Dept">
<id property="deptId" column="dept_id" />
<result property="deptName" column="dept_name" />
<result property="deptAddress" column="dept_address" />
</resultMap>
<!-- 这时的id就需要和dao接口的方法一致了 -->
<select id="selectOne" parameterType="int" resultMap="deptResultMap">
select * from dept where dept_id=#{id}
</select>
</mapper>
3)业务类中,使用@Autowired为DAO接口注入对象
public class DeptServiceImpl {
@Autowired
private DeptDao deptDao;
//省略其它代码