Spring+Mybatis dao层interface不加注解、dao层与sql建立对应关系

MapperScannerConfigurer

1、dao层不加注解,仍可以被容器获取bean并注入到其他类中

2、dao层与sql建立对应关系

以上实现,均通过 MapperScannerConfigurer 配置实现


     ....
     //数据库基本配置,账号、密码、连接池等等



    
    



    
    

mapperLocations:sql的xml文件目录

basePackage:dao层interface目录

官方文档中的配置:


  
  

org.mybatis.spring.sample.mapper.UserMapper是一个dao层接口,我们创建一个MapperFactoryBean实例,然后注入UserMapper接口和sqlSessionFactory。

之后想使用这个UserMapper接口的话,直接通过spring注入这个bean,然后

就可以直接使用了,spring内部会创建一个这个接口的动态代理。

当发现要使用多个MapperFactoryBean的时候,一个一个定义肯定非常麻烦,于是mybatis-spring提供了MapperScannerConfigurer这个类,它将会查找类路径下的映射器并自动将它们创建成MapperFactoryBean。


  

这段配置会扫描org.mybatis.spring.sample.mapper下的所有接口,然后创建各自接口的动态代理类。

MapperScannerConfigurer,让它扫描特定的包,自动帮我们成批地创建映射器。这样就大大减少了配置的工作量。
basePackage属性是让你为映射器接口文件设置基本的包路径。可以使用分号或逗号作为分隔符设置多于一个的包路径。

示例

通过上述方式,注册interface UserDao,并在UserServiceImpl中注入:

public class UserServiceImpl{
    @Autowried
    private UserDao userDao;

    
}

debugger模式查看userDao实例,发现是一个MapperProxy类的实例。而MapperProxy的源码,实现了InvocationHandler,说明使用了jdk自带的动态代理。

Spring+Mybatis dao层interface不加注解、dao层与sql建立对应关系_第1张图片

你可能感兴趣的:(Spring+Mybatis dao层interface不加注解、dao层与sql建立对应关系)