Mybatis每次创建时都会使用一个对象工厂(ObjectFactory)实例。可以从头开始理解一下执行过程:
xml或者配置文件–>SqlSessionFactoryBuilder–>SqlSessionFactory–>SqlSession–>执行SQL 语句(SQL Mapper)
-
开始时会通过xml文件或者配置文件生成SqlSessionFactory,注意SqlSessionFactory是由SqlSessionFactoryBuilder创建的,SqlSessionFactoryBuilter创建成功SqlSessionFactory之后就失去了它的作用,所以SqlSessionFactoryBuilder实例的作用就是创建SqlSessionFactory。不会长期存在,SqlSessionFactoryBuider的作用域是局部的。
-
SqlSessionFactory作为一个数据库连接池的作用是创建SqlSession接口对象。Mybatis其实是Java对数据库的操作,所以SqlSessionFactory的生命周期存在于整个Mybatis程序中,会长期保存,直至不再使用Mybatis。SqlSessionFactory在使用时占据着数据库的资源,如果创建多个就会导致数据库资源被耗光出现系统宕机等情况。
-
SqlSession作为连接数据库的连接对象(Connection对象),可以执行多条SQL语句,通过它自身的办法提交执行事务。所以它在处理完请求之后应该关闭连接,归还给SqlSessionFactory,否则会使数据库资源被耗光,我们可以使用try…catch…finally…来保证其正确关闭。所以SqlSession的生命周期在执行SQL语句,提交或操作事务时存在,SqlSession的作用域是方法作用域。