Fork me on GitHub

mybatis-01-基本流程

 

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功能架构及执行流程 参考:https://blog.51cto.com/12222886/2052647

 

posted @ 2019-03-01 13:24  youxiu326  阅读(130)  评论(0编辑  收藏  举报