sqlsession的生命周期以及相关问题

sqlsession的生命周期以及相关问题

网上整理 便于理解mybatis缓存中的一些概念

(一)、SqlSessionFactoryBuilder
  SqlSessionFactoryBuilder的作用就是在于创建SqlSessionFactory,创建成功后,SqlSessionFactoryBuilder就失去了作用,
所以它只能存在于创建SqlSessionFactory的方法中,而不要让其长期存在

(二)、SqlSessionFactory
  SqlSessionFactory可以被认为是一个数据库连接池,它的作用是创建SqlSession接口对象。因为MyBatis的本质就是Java对数据库的操作,
所以SqlSessionFactory的生命周期在于于整个MyBatis的应用之中,所以一旦创建了SqlSessionFactory的生命周期就等同于MyBatis的应用周期。

由于SqlSessionFactory是一个对数据库的连接池,所以它占据着数据库的连接资源。如果创建多个SqlSessionFactory,那么就存在多个数据库连接池,
这样不利于对数据资源的控制,也会导致连接资源被消耗光,出现系统宕机等情况,所以尽量避免发生这样的情况。因此在一般的应用中我们往往希望SqlSessionfactory作为一个单例,让它在应用中不共享。

当然:

SqlSeesionFactory默认就是一个单例的,用于创建SqlSession,SqlSessionFactory一旦创建成功,就不会再创建新的SqlSessionFactory

如果和Spring整合后,由spring管理SqlSeesionFactory,spring容器中的bean也是默认开启单例模式的

(三)、SqlSession
  如果说SqlSessionFactory相当于数据库连接池,那么SqlSession就相当于一个数据库连接(Connection对象),
你可以在一个事务里面执行多条SQL,然后通过它的commit、rollback等方法,提交或者回滚事务。所以它应该存活在一个业务请求中,
处理完整个请求后,应该关闭这条连接
,让它归还给SqlSessionFactory,否则数据库资源就很快被消耗精光,系统应付瘫痪,所以用try…catch…fanally语句来保证其正确关闭。

SqlSession:是一个面向一个面向用户操作数据库的接口,通过SqlSeesionFactory获取SqlSession,每次数据操作都需要创建新的SqlSession,

SqlSession不是线程安全,最佳应用场合是在方法体内,在方法中定义一个SqlSession局部变量,

注意:如果定义为成员变量的话,那么就有可以多个线程获取同一个SqlSession,那就有可能引发线程安全的问题

(四)、Mapper
  Mapper是一个接口,它由SqlSession所创建,所以它的最大生命周期至多和SqlSession保持一致,尽管它很好用,
但是由于SqlSession关闭,它的数据库连接资源也会消失,所以它的生命周期应该小于等于SqlSession的生命周期。
Mapper代表是一个请求中的业务处理,所以它应该在一个请求中,一旦处理完了相关的业务,就应该废弃它。

spring中的mybatis的sqlSession是如何做到线程隔离的

你可能感兴趣的:(mybatis,java)