【MyBatis】SqlSession相关的生命周期及作用域

【MyBatis】SqlSession相关的生命周期及作用域

 

 

生命周期,和作用域,是至关重要的,因为错误的使用会导致非常严重的并发问题

SqlSessionFactoryBuilder:

  • 一旦创建了 SqlSessionFactory,就不再需要它了

  • 局部变量

SqlSessionFactory:

  • 说白了就是可以想象为 :数据库连接池

  • SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。

  • 因此 SqlSessionFactory 的最佳作用域是应用作用域。

  • 最简单的就是使用单例模式或者静态单例模式。

SqlSession

  • 连接到连接池的一个请求!

  • SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。

  • 用完之后需要赶紧关闭,否则资源被占用!

 

这里面的每一个Mapper,就代表一个具体的业务!

但是每个Mapper可以运行多个业务(方法)

【MyBatis】SqlSession相关的生命周期及作用域

上一篇:mysql - 事务相关概念


下一篇:MySQL多表操作(一对一 一对多 多对多)