Spring+Mybatis dao层interface不加注解、dao层与sql建立对应关系
MapperScannerConfigurer1、dao层不加注解,仍可以被容器获取bean并注入到其他类中2、dao层与sql建立对应关系以上实现,均通过 MapperScannerConfigurer 配置实现<bean id="dataSource" ....>....//数据库基本配置,账号、密码、连接池等等</bean>...
MapperScannerConfigurer
1、dao层不加注解,仍可以被容器获取bean并注入到其他类中
2、dao层与sql建立对应关系
以上实现,均通过 MapperScannerConfigurer 配置实现
<bean id="dataSource" ....>
....
//数据库基本配置,账号、密码、连接池等等
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="mapperLocations" value="classpath:com/mysql/**/*.xml" />
</bean>
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.aaa.dao"/>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
</bean>
mapperLocations:sql的xml文件目录
basePackage:dao层interface目录
官方文档中的配置:
<bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="mapperInterface" value="org.mybatis.spring.sample.mapper.UserMapper" />
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>
org.mybatis.spring.sample.mapper.UserMapper是一个dao层接口,我们创建一个MapperFactoryBean实例,然后注入UserMapper接口和sqlSessionFactory。
之后想使用这个UserMapper接口的话,直接通过spring注入这个bean,然后
就可以直接使用了,spring内部会创建一个这个接口的动态代理。
当发现要使用多个MapperFactoryBean的时候,一个一个定义肯定非常麻烦,于是mybatis-spring提供了MapperScannerConfigurer这个类,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="org.mybatis.spring.sample.mapper" />
</bean>
这段配置会扫描org.mybatis.spring.sample.mapper下的所有接口,然后创建各自接口的动态代理类。
MapperScannerConfigurer,让它扫描特定的包,自动帮我们成批地创建映射器。这样就大大减少了配置的工作量。
basePackage属性是让你为映射器接口文件设置基本的包路径。可以使用分号或逗号作为分隔符设置多于一个的包路径。
示例
通过上述方式,注册interface UserDao,并在UserServiceImpl中注入:
public class UserServiceImpl{
@Autowried
private UserDao userDao;
}
debugger模式查看userDao实例,发现是一个MapperProxy类的实例。而MapperProxy的源码,实现了InvocationHandler,说明使用了jdk自带的动态代理。
更多推荐
所有评论(0)