博客
关于我
Mybatis中使用代理dao的执行过程分析
阅读量:692 次
发布时间:2019-03-17

本文共 359 字,大约阅读时间需要 1 分钟。

首先基于,我们分析如下:

在这里插入图片描述
找到SqlSession的实现类DefaultSqlSession并找到它的getMapper方法:
在这里插入图片描述
继续进入Configuration类中找到它的getMapper方法:
在这里插入图片描述
继续进入mapperRegistry类中找到getMapper方法:
在这里插入图片描述
接着进入MapperProxyFactory类中找到newInstance方法:
在这里插入图片描述
这里可以看出使用了动态代理,newProxyInstance第一个参数为类加载器,第二个参数为实现接口,第三个参数为如何代理。
接下来进入MapperProxy看看是如何进行代理:
在这里插入图片描述
可以看出执行了execute:
在这里插入图片描述
接着我们进入executeForMany:
在这里插入图片描述
通过上面分析可以看出Mybatis帮我们做了一系列工作,所以我们可以不用实现dao接口。
可以结合这篇文章看

转载地址:http://wuchz.baihongyu.com/

你可能感兴趣的文章
Mysql索引底层结构的分析
查看>>
MySQL索引底层:B+树详解
查看>>
Mysql索引总结
查看>>
MySQL索引背后的数据结构及算法原理
查看>>
mysql经常使用命令
查看>>
MySQL缓存使用率超过80%的解决方法
查看>>
Mysql缓存调优的基本知识(附Demo)
查看>>
mysql网站打开慢问题排查&数据库优化
查看>>
mysql自动化同步校验_Shell: 分享MySQL数据同步+主从复制自动化脚本_20190313_七侠镇莫尛貝...
查看>>
mysql自增id超大问题查询
查看>>
MySQL获取分组后的TOP 1和TOP N记录
查看>>
MySQL蜜罐反制获取攻击者信息
查看>>
Mysql表创建外键报错
查看>>
mysql表格调取数据库信息_MySQL™ 参考手册(获取有关数据库和表的信息)
查看>>
MySQL视图
查看>>
mysql视图建立MERGE算法和TEMPTABLE算法的区别(效率与表锁定问题)
查看>>
MySQL设置白名单限制
查看>>
MySQL设置远程连接
查看>>
Mysql账号权限查询(grants)
查看>>
MySQL迁移到达梦:如何轻松、高质量完成迁移任务
查看>>