mybatis工作原理

引导层------>框架支撑层----->数据处理------->接口层

1、创建sqlSessionFactoryBuilder对象

2、build(inputStream)

3、创建解析器parser

4、解析每一个标签把详细信息保存在Configuration中

5、解析mapper.xml

mapper.xml中每一个元素信息,解析并保存在全局配置文件中,将增删改查标签的每一个标签每一个属性都解析出来封装成一个mapperstatement,一个mapperstatement代表增删改查的详细信息,

config对象所有配置文件中的详细信息(封装)

总结:把配置文件的信息解析并保存在configuration中,返回DefaultSqlSession对象

1、获取sqlSessionFactory对象 :解析文件的每一个信息保存在configuration中返回包含configuration的defaultsessionfactory(马批评而statement代表一个增删改查的详细信息)

2、获取sqlSession对象:返回sqlSession的实现类DefaultsqlSession对象,里面包含了Executer的configuration,executor被创建

3、获取接口的代理对象:getMapper,使用MapperProxyFactory创建一个mapperProxy

4、执行增删改查方法

总结:1、根据配置文件(全局文件)映射初始化出configuration对象

2、创建一个DefaultsqlSession对象(configuration以及Executor根据全局配置文件的defaultExecutorType)创建出对应的Executor

3、DefaultSqlSession.getMapper():拿到Mapper接口对应的mapperProxy

4、MapperProxy里面有(DefaultSqlSession)

5、执行增删改查方法

            1、调用DefaultSqlSession的增删改查Executor

             2、会创建一个statementHandler对象同时也会创建ParameterHandler

             3、调用statementHandler预编译参数以及设置参数值ResultSetHandler

             4、调用statementHandler的增删改查方法

             5、ResultSetHandler对象

 

posted @ 2019-07-10 16:00  繁春  阅读(126)  评论(0编辑  收藏  举报