Mybatis执行流程(原理,面试官问题),可以直接背诵,通俗易懂,全面

解析xml文件

你可以这么回答: 在这个过程中,我们主要是为了获取SqlSession,利用sqlsession去执行相应的sql语句.

  1. 首先,根据SqlSessionFactoryBuilder的build方法,获取一个DefaultSqlSesionFactory对象,那么在build方法里会对xml文件进行解析,最主要是对主配置文件进行解析,主要通过XMLConfigBuilder类完成,生成一个Configuration对象.其次会对mapper.xml文件里的sql语句进行解析封装成一个MappeStatement对象放在Configuration的Map结构里,这个MappeStatement对象就是对对象关系映射,和一些sql语句的封装.
  2. 利用DefaultSqlSesionFactory的openSession方法去获取一个SqlSession类型的DefaultSqlSession对象,在这个方法里,主要是利用Configuration对象去创造一个Executor.

查询相应的缓存(如果是查询操作的话)

SqlSession 对象会根据用户接口层找到对应的MapperStatement.然后通过Executor对MapperStatement进行一个解析,先生成一个key,去查询二级缓存,如果二级缓存中没有,则向一级缓存中查询,如果有,就返回,如果没有,执行下一步.

执行对应的sql语句

Executor解析后,会生成对应的sql语句,并完成参数映射,比如,利用ParameterHandler设置参数.并封装成jdbc层面的Statement对象.
之后,jdbc层面进入prepareStatement方法进行预编译,然后执行相应的sql语句.

返回结果集

还是根据MapperStatement的对象关系映射,利用利用resultSetHandler处理器进行结果集包装,包装成map,对象这些结构,然后进行返回.

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值