码迷,mamicode.com
首页 > 其他好文 > 详细

mybatis工作原理

时间:2019-07-10 16:27:56      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:str   builder   parameter   ram   mapper   mic   原理   sql   default   

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

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对象

技术图片

 

mybatis工作原理

标签:str   builder   parameter   ram   mapper   mic   原理   sql   default   

原文地址:https://www.cnblogs.com/cye9971-/p/11164549.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!