Mybatis—生命周期和作用域
程序运行时,mybatis的加载运行过程如上
SqlSessionFactoryBuilder
1.SqlSessionFactoryBuilder:从xml配置文件中加载配置参数,用于创建一个SqlSessionFactory工厂。之后程序与之打交道的只有SqlSessionFactory 和 SqlSession,因此这个工厂建造者不用给太长的生命周期、太大的作用域。
2.它的生命周期只有在创建SqlSessionFactory工厂时需要,创建完工厂之后可以立即失效(局部变量)
SqlSessionFactory
1.SqlSessionFacory给我的理解就是一个数据库连接池,当业务层需要操作数据库时从SqlSessionFatory中获取一个Session,最后进行操纵。
2.因此一旦被创建就应该在应用的运行期间一直存在、最佳作用域是应用作用域;没有任何理由丢弃它或重新创建另一个实例。
3.由于它的单一性,我们可以使用单例模式或者静态单例模式进行创建。
SqlSession
1.SqlSession就是一个的数据库连接,类似于JDBC中的Connection对象。
2.使用SqlSession执行SQL语句,因此它应该存活在一个业务请求中,处理完整个请求后,应该立即关闭这条连接,将其归还给SqlSessionFactory工厂。
3.SqlSession的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
Mapper
1.Mapper映射器用于绑定需要执行的业务(SQL语句)。
2.它的生命周期应该小于等于SqlSession的生命周期。