java - Mybais 会话session是否公用
本文介绍了java - Mybais 会话session是否公用的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
问题:使用mybatis时,一个sqlsessionfactory.opensession的方法,能否同时兼容多个dao的操作
例如,我在pojo a 的dao,aDAO的插入操作中,实例化了一个session,
SqlSession session = sqlSessionFactory.openSession();
ADAO aDAO = session.getMapper(ADAO.class);
此时由于我要同时对pojo b进行一些操作,那么我可不重新实例化新的session,而是直接使用之前实例的session a
BDAO bDAO = session.getMapper(BDAO.class)
如果可以这么操作的话,请问有什么限制(因为如果是删除,增加,更新的操作的话,是需要提交会话的,而查询不需要)
解决方案
mybatis
中通过SqlSessionManager
这个类来管理Session
的话,每一个线程是公用的一个Session
mybatis-spring
这个集成插件中,对于没有启用事务的一条查询/更新语句对应一个Session
,如果开启了事务,在这个事务中的查询/更新都是公用一个Session
mybatis
中的Executor
不是线程安全的,所以最多只能在一个线程中复用Session
这篇关于java - Mybais 会话session是否公用的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文