博客
关于我
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如何实现ACID ?
查看>>
mysql如何记录数据库响应时间
查看>>
MySQL子查询
查看>>
Mysql字段、索引操作
查看>>
mysql字段的细节(查询自定义的字段[意义-行列转置];UNION ALL;case-when)
查看>>
mysql字段类型不一致导致的索引失效
查看>>
mysql字段类型介绍
查看>>
mysql字段解析逗号分割_MySQL逗号分割字段的行列转换技巧
查看>>
MySQL字符集与排序规则
查看>>
MySQL字符集乱码
查看>>
mysql字符集设置
查看>>
mysql存储IP地址的数据类型
查看>>
mysql存储中文 但是读取乱码_mysql存储中文乱码
查看>>
MySQL存储引擎
查看>>
MySQL存储引擎--MYSIAM和INNODB引擎区别
查看>>
Mysql存储引擎(2):存储引擎特点
查看>>
MySQL存储引擎--MyISAM与InnoDB区别
查看>>
mysql存储总结
查看>>
mysql存储登录_php调用mysql存储过程会员登录验证实例分析
查看>>