mapper配置有多种方法:
- 原始的dao接入的方法,即写好dao接口类,写好实现类impl,实现类要继承org.mybatis.spring.support.SqlSessionDaoSupport,然后在spring配置文件里面配置
public class TestDaoImpl extends SqlSessionDaoSupport implements TestMapper {
@Override
public Test getById(int id) {
String statement="org.kay.mapping.testMapper.getById";
SqlSession session=this.getSqlSession();
Test t1=session.selectOne(statement,id);
return t1;
}
}
<bean id="testDao" class="org.kay.dao.impl.TestDaoImpl">
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
</bean>
2.配置org.mybatis.spring.mapper.MapperFactoryBean的bean对象,写好dao接口,让spring生成代理对象
—-在mybatis配置文件中要配置mapper.xml位置,缺点是,当有很多的mapper需要配置时,无法使用mybatis的自动扫包,需要一个一个配置文件的手动配置。
所以可以采用第三个方法。
<bean id="testMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="mapperInterface" value="org.kay.dao.TestMapper"/>
<property name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
3.批量配置mapper,使用MapperScannerConfigurer
注意:--扫面basePackage包下的所有mapper,mapper接口要与对应的mapper.xml文件在同一个包,且命名相同。
不这样规范也可以,在整合mybatis的时候可以这样扫描所有mapper.xml,但是 要注意的是 mapper.xml中的命名空间需要命名为
对应的mapper接口的包名+完全限定名,比如mapper接口为org.kay.dao.UserDAO,则对应的命名空间为也为org.kay.dao.UserDAO:
<!--spring整合mybatis文件,这样就不用mybatis配置了 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="mapperLocations" value="classpath:org/kay/mapping/*.xml"/>
</bean>
---扫描出来生成的bean对象的id值为 mapper类名(首字母小写)。
---在mybaits.xml配置文件中不用再配置<mapper>
---如果要制定生成的bean的id属性,可以在mapper接口上使用@Component注解指定名称(或者javax.inject.Named注解)
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="org.kay.dao"/>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
</bean>
@Component("test1")
//该注解会使spring自动生成mapper的bean时使用指定名称
public interface TestMapper {
public Test getById(int id);
}