mybatis 无法new sqlsessionfactory();_MyBatis的运行原理

6902318bd4f9516ecc66decf8a00d6f1.png

要执行sql语句必须得到一个SqlSession,那么我们是怎么获得这个对象的呢

第一步:通过Resources加载配置好的mybatis.xml配置文件。Resources是http://ibatis.io包下面的类,也就是一个io流,用于读写文件,通过getResourceAsStream把xml文件加载进来,降配置文件解析为一个流。

  第二步:然后看第二句话,这句话是关键。我们首先new了一个SqlSessionFactoryBuilder对象,他是SqlSessionFactory的构建者。我们调用了他的build()方法。这个方法长什么样子呢

cece73855c91f4f0a450f4352800008a.png

我们发现里面有一个XMLconfigBuilder对象

他是用来解析XML文件的一个构建者,通过他的parse()方法解析xml文件

8370b938b9482315fb1fb97ae741ed42.png

解析完成后,他返回了一个configuration对象

它是用来存放mybatis核心配置文件解析完成后的结果

b973004fc0b6df870d052bf2f34172fe.png

他又返回了一个build方法,把刚才的返回值configuration作为参数传入这个方法中,并返回了一个DefaultSqlSessionFactory对象,这是SqlSessionFactory的实现类,用来生产defaultSqlSession对象 这才结束

第三步

2b41a31bc63b8572a60968c529322bbd.png

ransaction,这很明显是一个事务,我们都知道sql执行时都要涉及到事务操作的

总结:mybatis运行时要先通过resources把核心配置文件也就是mybatis.xml文件加载进来,然后通过xmlConfigBulider来解析,解析完成后把结果放入configuration中,并把它作为参数传入到build()方法中,并返回一个defaultSQLSessionFactory。我们再调用openSession()方法,来获取SqlSession,在构建SqlSession的同时还需要transaction和executor用于后续执行操作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值