数据库
首页 > 数据库> > SqlSession的执行流程

SqlSession的执行流程

作者:互联网

一、四大组件


1、Executor(执行器)

Executor:顶级接口

      CacheingExector:处理二级缓存

      BaseExector:处理一级缓存(抽象类,具体实现由子类实现)

           SimpleExector:执行简单的JDBC代码(日常用的都是这个)

           BatchExcetor:批处理执行JDBC代码

           ReuseExcetor:可重用statement执行JDBC代码

2、StatementHandler

StatementHandler:顶级接口

      RoutingStatementHandler:路由,确定由哪个StatementHandler实现

      BaseStatementHandler:抽象类,具体实现由子类实现

           SimpleStatementHandler:简单StatementHandler,注入了RoutingStatementHandler属性,实现路由分配

           PrepareStatementHandler:预处理statementHandler(日常都是用的这个)

           CallableStatementHandler:存储过程statementHandler

3、ParameterHandler

ParameterHandler 译为参数处理器,负责为 PreparedStatement 的 sql 语句参数动态赋值

4、ResultSetHandler

ResultSetHandler接口就是将ResultSet结果集映射为Bean、List、Map等Java中的对象或者集合。

二、执行流程


SqlSession#selectList

     |—CachingExecutor#query:从二级缓存中获取查询结果

            |—MappedStatement#getBoundSql:获取执行的sql语句

            |—CachingExecutor#createCacheKey:生成sql语句的缓存

            |—CachingExecutor#query:从二级缓存中查找,对应的数据如果有则返回,没有则向一级缓存查找

                  |—BaseExecutor#query:从一级缓存中查找,若有则返回,没有则查询数据库

                         |—BaseExecutor#queryFromDatabase:将当前的sql语句缓存到一级缓存中

                               |—SimpleExecutor#doQuery:真正的查询数据库的方法

                                    |—Configuration#newStatementHandler:获取StatementHandler对象,即StatementHandler的创建入口

                                    |—SimpleExecutor#prepareStatement:给StatementHandler对象设置参数

                                    |—RoutingStatementHandler#query:路由StatementHandler,确认到底真正干活的是PreparedStatementHandler

                                           |—PreparedStatementHandler#构造方法

                                                   |—Configuration#newParameterHandler:初始化ParameterHandler,即ParameterHandler的创建入口

                                                   |—Configuration#newResultSetHandler:初始化ResultSetHandler,即ResultSetHandler的创建入口

                                          |—PreparedStatementHandler#query:执行jdbc操作,即真正的和数据库底层操作

                                                  |—DefaultResultSetHandler#handleResultSets:处理查询出来的结果集

 

 

 

 

 

标签:缓存,流程,sql,ParameterHandler,SqlSession,ResultSetHandler,query,StatementHandler,执行
来源: https://blog.csdn.net/qq_37343202/article/details/110326414