mybatis SqlSession事务
2024-10-21 03:15:42
mybatis版本:3.4.6。
mybatis默认的SqlSessionFactory是DefaultSqlSessionFactory,它openSession()的源码是:
public SqlSession openSession() {
return this.openSessionFromDataSource(this.configuration.getDefaultExecutorType(), (TransactionIsolationLevel)null, false);
}
private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) {
Transaction tx = null; DefaultSqlSession var8;
try {
Environment environment = this.configuration.getEnvironment();
TransactionFactory transactionFactory = this.getTransactionFactoryFromEnvironment(environment);
tx = transactionFactory.newTransaction(environment.getDataSource(), level, autoCommit);
Executor executor = this.configuration.newExecutor(tx, execType);
var8 = new DefaultSqlSession(this.configuration, executor, autoCommit);
} catch (Exception var12) {
this.closeTransaction(tx);
throw ExceptionFactory.wrapException("Error opening session. Cause: " + var12, var12);
} finally {
ErrorContext.instance().reset();
} return var8;
}
可以看到,mybatis默认每次获取session都会开启一个事务,且不自动提交事务。如果更新操作完成后不手动commit,则在连接断开时会将更新操作回滚。
SqlSession session = MybatisUtil.getSession();
UserMapper userMapper = session.getMapper(UserMapper.class);
try{
UserDomain newUserDomain = new UserDomain();
newUserDomain.setAge(10);
newUserDomain.setName("scp2");
newUserDomain.setSchool("高中");
userMapper.insert(newUserDomain);
session.commit();// 如果不commit,连接断开时操作会被回滚
}
catch (Exception e){
System.out.println(e);
}
finally {
if (null != session) {session.close();}
}
最新文章
- PLSQL note
- 操作数数据类型 ntext 对于 max 运算符无效
- mysql中char与varchar的区别分析
- 必备:常用px,pt,em换算表(转)
- Java方法的封装
- SQL Server查看所有表大小、表行数和占用空间信息
- svn: warning: 'xxxxxx' is already under version control
- 事件监听addEventListener()和removeEventListener() ---------1
- Js获取URL中的QueryStirng字符串
- [Redux] Extracting Container Components (FilterLink)
- 基于eclipse的mybatis映射代码自动生成的插件
- PHP学习笔记7-JSON数据操作
- DAO设计模式实现数据库的增删改查(进一步封装JDBC工具类)
- mysql常见操作汇总
- CentOS6.8安装python2.7以及XX-Net
- 两个arduino的通信
- Dynamics CRM 2013 SP1 客户表单界面上联系人subgrid上的添加现有联系人功能缺失
- js中的数据类型、以及浅拷贝和深拷贝
- linux中断源码分析 - 初始化(二)
- Post Tuned Hashing,PTH