要想操作数据库,需要执行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