mybatis的各个组件的作用域与生命周期

mybatis的各个组件的作用域与生命周期:
SQLSessionFactoryBuilder:
SQLSessionFactoryBuilder的作用在于创建SQLSessionFactory,创建成功后,
SQLSessionFactoryBuilder就失去了作用,所有它只能存在与创建SQLSessionFactory的
方法中,而不要让其长期存在。因此SQLSessionFactoryBuilder实例的最佳作用域是
方法作用域。
SQLSessionFactory:
SQLSessionFactory可以被认为是一个数据库连接池,它 的作用是创建SQLSession
接口对象。因为mybatis的本质就是Java对数据库的操作,所以SQLSessionFactory的
生命周期存在于整个mybatis 的应用之中 ,所以一旦创建了SQLSessionFactory,就要
长期保存它,直至不再使用Mybatis应用,所以可以认为SQLSessionFactory的声明周期
等同于mybatis的应用周期。
由于SQLSessionFactory是一个对数据库的连接池,所以它占据着数据库的连接资源。
如果创建多个SQLSessionFactory,那么就存在多个数据库连接池,这样不利于对数据库
资源的控制,也会导致数据库连接资源被消耗光,出现系统宕机等情况,所以尽量避免
发生这样的情况。因此在一般的应用中我们往往希望SQLSessionFactory作为一个单例,
让它在应用中被共享。所以说SQLSessionFactory的最佳作用域是应用作用域。
SQLSession:
如果说SQLSessionFactory相当于数据库连接池,那么SQLSession就相当于一个数据库
连接,你可以在一个事务里面执行多条SQL,然后通过它的commit、rollback等方法,提交
或者回滚事务。所以它应该存活在一个业务请求中,处理完整个请求后,应该关闭这条连接,
让它归还给SQLSessionFactory,否则数据库资源就很快被耗费精光,系统就会瘫痪,所以用
try…catch…finally…语句来保证其正确关闭。因此SQLSession的最佳的作用域是请求
或方法作用域。
Mapper:
Mapper是一个接口,它由SQLSession所创建,所以它的最大生命周期至多和SQLSession
保持一致,尽管它很好用,但是由于SQLSession的关闭,它的数据库连接资源也会消失,所以
它的生命周期应该小于等于SQLSession的声明周期。Mapper代表的是一个请求中的业务处理,
所以它应该在一个请求中,一旦处理完了相关的业务,就应该废弃它。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值