数据库
首页 > 数据库> > MyBatis:SqlSession.getMapper()源码分析

MyBatis:SqlSession.getMapper()源码分析

作者:互联网

要想操作数据库,需要执行mapper文件中的SQL语句,而其对应的是dao接口中的方法,所以需要一个具有dao接口方法的实现类,mybatis底层通过动态代理,根据dao接口生成了一个代理对象,即实现类(eg:studentDao),进而调用其中的操作方法。

更加细致的过程如下转载中描述的非常不错:

1、Mybatis 读取XML配置文件后会将内容放在一个Configuration类中,SqlSessionFactoryBuilder会读取Configuration类中信息创建SqlSessionFactory。

2、在初始化SqlSessionFactory时,Mapper 接口进行注册,注册在了名为 MapperRegistry 类的 HashMap中,

key = Mapper class, value = 创建当前Mapper的工厂。

3、SqlSessionFactory创建SqlSession。

4、SqlSession中可以通过getMapper()拿到代理对象,SqlSession.getMapper 运用了 JDK动态代理,产生了目标Mapper接口的代理对象。

5. 动态代理的 代理类是 MapperProxy ,这里边mapperMethod.execute(sqlSession, args)最终完成了增删改查方法的调用。
————————————————
版权声明:本文为CSDN博主「Lin_Dong_Tian」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_40645822/article/details/101844675

 

标签:Mapper,getMapper,dao,代理,接口,SqlSession,源码,MyBatis
来源: https://www.cnblogs.com/devinseu/p/15151743.html