MyBatis:SqlSession.getMapper()源码分析

2021/8/17 19:37:41

本文主要是介绍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

 



这篇关于MyBatis:SqlSession.getMapper()源码分析的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程