目录
关于SqlSession的,会另起一篇文章介绍,本次关于Mapper接口的代理就到这里了,谢谢大家。
一.关系梳理
二.Configuration
配置实体,可以理解为读取了xml配置文件后生成的配置实体。
三.MapperRegistry
是Configuration里面的一个类变量,可用于扫描mapper接口时,通过addMapper方法加载Mapper的Bean到knowsMappers中。 这里保存的是MapperProxyFactory,并非MapperProxy。
四.MapperProxyFactory
- 在“MapperRegistry”中用到,一个“MapperProxyFactory”对应一个mapperInterface。
- methodCache这个缓存对象会传入到MapperProxy对象中,由MapperProxy进行写入MapperMethod数据。
- 通过newInstance方法生成一个MapperProxy(Mapper代理)。
- 有2个newInstance方法,只有newInstance(SqlSession sqlSession)是对外开放的。
关于newInstance中的参数sqlSession是怎么来的:
这里涉及到spring加载dao层实体的流程,具体与“SqlSessionTemplate”、“MapperFactoryBean”、“MapperScannerRegistrar”等实现有关,这里不细说,有兴趣的同学可以通读源码了解。
五.MapperProxy
这个类实现了“InvocationHandler”接口进行反射操作。
反射操作invoke()中会拿到调用的MapperMethod对象,通过执行MapperMethod的execute方法完成用户的命令
六.MapperMethod
1.MapperMethod在生成的时候已经确认“SqlCommand”,即sql的类型(增删改查)。
2.在execute方法中,根据SqlCommand和传入的参数,会选择对应的具体(增删改查)方法执行,并对结果进行加工,可以理解MapperMethod只是一个路由。
3.那么在execute中执行sql,要怎么与数据库通信呢(事务、数据库连接、Statement等等)?
(1)这就涉及到Mybatis中的一个核心了,就是SqlSession(会话)。在程序运行时,所有数据库命令执行都是在SqlSession下进行的。
(2)SqlSession是一个接口,他的实现类有“DefaultSqlSession”,“SqlSessionManager”,“SqlSessionTemplate”。各自有自己的应用场景,
但是最终都是通过“DefaultSqlSession”去实现具体的数据库访问逻辑。