第一种.需要Mapper实现类
总体的项目结构
实现类 customerMapperimpl.java
package com.zopho.dao.impl;
import com.zopho.dao.customerMapper;
import com.zopho.domain.customer;
import org.apache.ibatis.session.SqlSession;
import org.mybatis.spring.support.SqlSessionDaoSupport;
public class customerMapperimpl extends SqlSessionDaoSupport implements customerMapper {
public void addcustomer(customer customer) {
SqlSession sqlSession = this.getSqlSession();
sqlSession.insert("addcustomer",customer);
//不需要事务提交
}
}
Spring的配置文件 applicationContext.xml
<!--创建sqlsessionfactroy对象-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--关联连接池-->
<property name="dataSource" ref="dataSource"/>
<!--加载sql映射文件-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!--为impl注入factroy-->
<bean id="customerMapper" class="com.zopho.dao.impl.customerMapperimpl">
<!--关联factory-->
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
第二种.不需要Mapper实现类
总体的项目结构
Mapper实现类已经被我们删除
Spring的配置文件 applicationContext.xml
利用org.mybatis.spring.mapper.MapperFactoryBean
<!--创建sqlsessionfactroy对象-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--关联连接池-->
<property name="dataSource" ref="dataSource"/>
<!--加载sql映射文件-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!--配置Mapper接口-->
<bean id="customerMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<!--关联Mapper接口-->
<property name="mapperInterface" value="com.zopho.dao.customerMapper"/>
<!--关联sqlsessionfactroy-->
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
MapperFactoryBean的出现为了代替手工使用SqlSessionDaoSupport或SqlSessionTemplate编写数据访问对象(DAO)的代码,使用动态代理实现。
org.mybatis.spring.sample.mapper.UserMapper是一个接口,我们创建一个MapperFactoryBean实例,然后注入这个接口和sqlSessionFactory(mybatis中提供的SqlSessionFactory接口,MapperFactoryBean会使用SqlSessionFactory创建SqlSession)这两个属性。
之后想使用这个UserMapper接口的话,直接通过spring注入这个bean,然后就可以直接使用了,spring内部会创建一个这个接口的动态代理。
当发现要使用多个MapperFactoryBean的时候,一个一个定义肯定非常麻烦,于是mybatis-spring提供了MapperScannerConfigurer这个类,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。
也就是我们的第三种方法
第三种.Mapper接口扫描
Spring的配置文件 applicationContext.xml
<!--创建sqlsessionfactroy对象-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--关联连接池-->
<property name="dataSource" ref="dataSource"/>
<!--加载sql映射文件-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!--配置Mapper扫描-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--关联Mapper包的路径-->
<property name="basePackage" value="com.zopho.dao"/>
</bean>
这段配置会扫描com.zopho.dao下的所有接口,然后创建各自接口的动态代理类。