生命周期 和作用域是至关重要的
因为错误的使用会导致非常严重的的并发问题
SqlSessionFactory:SqlSessionFactory可以被认为是一个数据库连接池,它的作用是创建SqlSession接口对象。因为MyBatis的本质就是java对数据库的操作,所以SqlSessionFactory的生命周期存在于整个MyBatis的应用之中,所以一旦创建了SqlSessionFactory,就要长期保存它,直至不再使用MyBatis应用,所以可以认为SqlSessionFactory的生命周期就等同于Mybatis的应用周期。
SqlSessionFactory 可以通过 SqlSessionFactoryBuilder来获得
//这段代码是从mybatis 官网拿下来的 ,是固定的 把它放到静态代码块中 是因为 这样可以早于类的加载
String resource = "mybatis-config.xml";//这里注意别写错 这个是与resources 文件下 的文件名
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
SqlSessionFactoryBuilder 可以从XML配置文件(mybatis-config.xml)构建出SqlSessionFactory的实例。SqlSessionFactoryBuilder 只需要创建一次即可
SqlSession: 如果说SqlSessionFactory相当于数据连接池,那么SqlSession就相当于一个数据连接(Connection对象),你可以在一个事务里面执行多条SQL,然后通过commit,rollback等方法,提交或者回滚事务。所以它应该存活在一个业务请求中,处理完整个请求后,应该关闭这条连接,让它归还SqlSessionFactory,否则数据库资源就很快被耗费精光,系统就会瘫痪,所以用try…catch…finally语句来保证其正确关闭。所以SqlSession的最佳作用域是请求或方法作用域。也就是局部方法变量。
用完之后需要赶紧关闭,否则资源被占用!
****所以总结生命周期
SqlSessionFactoryBuilder :全程就创建一次,一旦创建 就不需要它了
SqlSessionFactory:一旦被创建就在应用的运行期间一直存在 ,直至不再使用MyBatis应用
SqlSession :从创建 到关闭 会一直存在
![理解图