[MyBatis] 如何让MyBatis支持代码级事务处理
MyBatis提供的sqlSession对象是可以用来帮助我们实现事务处理的,方式和JDBC的类似,具体请见代码:
import java.sql.Connection;
import java.sql.SQLException;
import java.text.Format;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import org.apache.ibatis.session.SqlSession;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import jp.co.rakuten.rtms.batch.common.exception.BatchApplicationException;
/**
* To verify the possibility of commit/rollback after a part of code
* @author Heyang
* @date 19.10.04
*/
@Component
public class SweepawayExpiredDataInDB_TestRollback2 extends AbstractJob implements Job {
/** SQL実行クラス */
@Autowired
private SqlSession session;
@Override
public void doExecute(String[] args) {
logger.info("SweepawayExpiredDataInDB_TestRollback started.");
long startTime = System.currentTimeMillis();
try {
logger.info("isAutoCommit="+session.getConnection().getAutoCommit());
Connection conn = session.getConnection();
conn.setAutoCommit(false);
try {
for(int i=0;i<10;i++) {
Map<String, String> para=new HashMap<String, String>();
para.put("id",String.valueOf(i));
para.put("name","Andy"+i);
session.insert("insertEmp", para);
}
conn.commit();
logger.info("1.Committed");
} catch (Exception e) {
conn.rollback();
logger.info("1.Rollbacked");
e.printStackTrace();
}
try {
for(int i=0;i<10;i++) {
Map<String, String> para=new HashMap<String, String>();
para.put("id",String.valueOf(i));
para.put("name","Andy"+i);
session.insert("insertEmp", para);
}
conn.commit();
logger.info("2.Committed");
} catch (Exception e) {
conn.rollback();
logger.info("2.Rollbacked");
e.printStackTrace();
}
try {
for(int i=0;i<10;i++) {
Map<String, String> para=new HashMap<String, String>();
para.put("id",String.valueOf(100+i));
para.put("name","Cindy"+i);
session.insert("insertEmp", para);
}
conn.rollback();
logger.info("3.Rollback mannualy");
} catch (Exception e) {
conn.rollback();
logger.info("2.Rollbacked");
e.printStackTrace();
}
//conn.commit();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{ session.close(); }
long endTime = System.currentTimeMillis();
double seconds=((double)endTime - (double)startTime)/1000;
logger.info("Time elapsed:" + seconds + "s");
logger.info("SweepawayExpiredDataInDB_TestRollback completed.");
}
}
--END-- 19.10.04 11:12
[MyBatis] 如何让MyBatis支持代码级事务处理的更多相关文章
- 【Mybatis】MyBatis之Generator自动生成代码(九)
MyBatis Generator 简介 MyBatis Generator 连接数据库表并生成MyBatis或iBatis文件.这有助于最大限度地减少使用MyBatis时为数据库文件创建简单CRUD ...
- MyBatis使用Generator自动生成代码
MyBatis中,可以使用Generator自动生成代码,包括DAO层. MODEL层 .MAPPING SQL映射文件. 第一步: 配置好自动生成代码所需的XML配置文件,例如(generator. ...
- 02 使用Mybatis的逆向工程自动生成代码
1.逆向工程的作用 Mybatis 官方提供了逆向工程,可以针对数据库表自动生成Mybatis执行所需要的代码(包括mapper.xml.Mapper.java.pojo). 2.逆向工程的使用方法 ...
- mybatis逆向工程--自动生成实体代码(mybatis-generator)
随便找个目录, 添加文件, 如图 主要是两个jar包, generator的下载路径: https://github.com/mybatis/generator/releases 驱动包随 ...
- Eclipse 使用mybatis generator插件自动生成代码
Eclipse 使用mybatis generator插件自动生成代码 标签: mybatis 2016-12-07 15:10 5247人阅读 评论(0) 收藏 举报 .embody{ paddin ...
- 使用Mybatis的逆向工程自动生成代码
1.逆向工程的作用 Mybatis 官方提供了逆向工程,可以针对数据库表自动生成Mybatis执行所需要的代码(包括mapper.xml.Mapper.java.pojo). 2.逆向工程的使用方法 ...
- Spring Boot MyBatis 通用Mapper 自动生成代码
一.在pom.xml文件中进入mybatis自动生成代码相关的jar包: 注意: <configurationFile>标签中配置的是“generatorConfig.xml”文件位置. ...
- MyBatis框架之mybatis逆向工程自动生成代码
http://www.jb51.net/article/82062.htm Mybatis属于半自动ORM,在使用这个框架中,工作量最大的就是书写Mapping的映射文件,由于手动书写很容易出错,我们 ...
- mybatis 逆向工程(通过数据库表针对单表自动生成mybatis执行所需要的代码)
mybatis需要程序员自己编写sql语句,mybatis官方提供逆向工程,可以针对单表自动生成mybatis执行所需要的代码(mapper.java.mapper.xml.pojo…),可以让程序员 ...
随机推荐
- Delphi 编写线程的清除代码
- 【转】char data[0]用法总结
@2019-07-31 struct MyData { int nLen; ]; }; 开始没有理解红色部分的内容,上网搜索下,发现用处很大,记录下来. 在结构中,data是一个数组名:但该数组没有元 ...
- java8 常用语法小结
// 判空 // 排序 //映射 //序列化
- 【小知识】证明 $1$ 到 $n$ 的立方和公式
scb 发明了小学奥数(确信) Formula \(\sum\limits_{i=1}^n i^3 = (\sum\limits_{i=1}^n i)^2\) Provement 构造一个矩阵 \(a ...
- Mysql导入Excel数据 日期问题 (Excel 与 MySQL 时间戳格式和日期 互转)
https://blog.csdn.net/ghw455954461/article/details/7247738 今天项目表中需要导入好几w条数据 ,但日期由两个一个是标准时间一个为时间戳,程序中 ...
- P3384 【模板】树链剖分 题解&&树链剖分详解
题外话: 一道至今为止做题时间最长的题: begin at 8.30A.M 然后求助_yjk dalao后 最后一次搞取模: awsl. 正解开始: 题目链接. 树链剖分,指的是将一棵树通过两次遍历后 ...
- 内网监控zabbix
告警 告警方式:linkedsee 类型:使用脚本linkedsee.sh [root@zabbix-server ~]# cat linkedsee.sh #! /bin/bash SERVICE_ ...
- python_三元运算符
三元运算又称三目运算,是对简单的条件语句的简写 简单条件语句: if 条件成立: val = 1 else: val = 2 改成三元运算: val = 1 if 条件成立 else 2 举例: a ...
- 关于iar intrinsics.h is already included previously!报错的问题及解决办法
用最新的cubemx生成f103的代码(带freertos系统),如果用iar编译,可能会出现intrinsics.h is already included previously!的错误,如果没有待 ...
- Java8-Stream-No.05
import java.util.Arrays; import java.util.List; import java.util.function.Supplier; import java.util ...