Java 笔记——MyBatis 生命周期
1.MyBatis 的生命周期
MyBatis的核心组件分为4个部分。
- SqlSessionFactoryBuilder (构造器): 它会根据配置或者代码来生成SqISessionFactory,采用的是分步构建的 Builder 模式。
- SqlSessionFactory (工厂接口): 依靠它来生成 SqlSession,使用的是工厂模式。
- SqlSession (会话): 一个既可以发送 SQL 执行返回结果,也可以获取 Mapper 的接口。在现有的技术中,一般我们会让其在业务逻辑代码中“消失”,而使用的是 MyBatis 提供的 SQLMapper接口编程技术,它能提高代码的可读性和可维护性。
- SQL Mapper (映射器): MyBatis 新设计存在的组件,它由 一个 Java 接口和 XML 文件 (或注解) 构成,需要给出对应的 SQL 和映射规则。它负责发送 SQL 去执行,并返回结果 。
2.生命周期
2.1.SqlSessionFactoryBuilder
SqlSessionFactoryBuilder 的作用在于创建 SqlSessionFactory,创建成功后,SqlSessionFactoryBuilder 就失去了作用,所以 SqlSessionFactoryBuilder 不需要长期存在,只作用于创建 SqlSessionFactory 的方法中即可。
2.2.SqlSessionFactory
SqlSessionFactory 可以被认为是一个数据库连接池,它的作用是创建 SqlSession 接口对象。SqlSessionFactory 的生命周期存在于整个 MyBatis 的应用之中,一旦创建了 SqlSessionFactory,就要长期保存它,直至不再使用 MyBatis 应用。MyBatis 的本质就是 Java 对数据库的操作。
一般的应用中我们往往希望 SqlSessionFactory 作为一个单例,让它在应用中被共享。因为 SqlSessionFactory 是一个对数据库的连接池,它占据着数据库的连接资源,如果创建多个 SqlSessionFactory,那么就存在多个数据库连接池,会导致数据库连接资源被消耗光。
2.3.SqlSession
SqlSession 就相当于一个数据库连接 (Connection 对象),你可以在一个事务里面执行多条 SQL,然后通过它的 commit、 rollback 等方法,提交或者回滚事务。所以它应该存活在一个业务请求中,处理完整个请求后,应该关闭这条连接,让它归还给 SqlSessionFactory,否则数据库资源就很快被耗费精光,系统就会瘫痪,所以用 try...catch...finally...语句来保证其正确关闭。
2.4.SQL Mappe
Mapper 是一个接口,它由 SqlSession 所创建,所以它的最大生命周期至多和 SqlSession 保持一致,但是由于 SqlSession 的关闭,它的数据库连接资源也会消失,所以它的生命周期应该小于等于 SqlSession 的生命周期。 Mapper 代表的是一个请求中的业务处理 ,所以它应该在一个请求中,一旦处理完了相关的业务,就应该废弃它。