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