mybatis执行流程
- 1. 加载配置文件并初始化(SqlSession)
- 配置文件来源于两个地方,一个是配置文件(主配置文件conf.xml,mapper文件*.xml),
- 一个是java代码中的注释,将sql的配置信息加载成为一个mappedstatement对象,存储在内存之中(包括传入参数的映射配置,结果映射配置,执行的sql语句)。
-
- 2. 接收调用请求
- 调用mybatis提供的api,传入的参数为sql的id(有namespase和具体sql的id组成)和sql语句的参数对象,mybatis将调用请求交给请求处理层。
-
- 3. 处理请求
- 根据sql的id找到对应的mappedstatament对象。
- 根据传入参数解析mappedstatement对象,得到最终要执行的sql。
- 获取数据库连接,执行sql,得到执行结果
- Mappedstatement对象中的结果映射对执行结果进行转换处理,并得到最终的处理结果。
- 释放连接资源
-
- 4. 返回处理结果
层级
- sqlSession
- sqlSessionFactory
- configuration
- mappedStatements
- 包含所有的mappedStatement 对象
-
-
-
-
idea断点调试
MapperProxy 代理Mapper中有一个sqlSession sqlSession中有sqlSessionFactory sqlSessionFactory中有一个configuration
configuration 中有一个 mappedStatements 中包含了所有mappedstatament集合,所有mapper中定义的方法保存在这里,可以看到
key:com.huarui.dao.postMapper.deleteByPrimarykey
value:
sqlSource:
sql: 对应的sql语句
mybatis功能架构及执行流程 参考: