[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…),可以让程序员 ...
随机推荐
- c#向指定的邮箱发送邮件
private bool SendEmail(string fileName) { MailMessage m_Mail = new MailMessage(); m_Mail.From = new ...
- oracle wm_concat函数用法
在Oracle中使用wm_concat(column)可以实现字段的分组合并,逗号分隔.
- mysql 利用 case 批量更新
- C#读取某一文件夹下的所有文件夹和文件
static List<string> list = new List<string>();//定义list变量,存放获取到的路径 /// <summary> // ...
- 【Struts2】进阶
一.Action处理请求参数 1.1 属性驱动 1.2 模型驱动 1.3 扩展 将数据封装到List集合 将数据封装到Map集合 二.类型转换 2.1 自定义类型转换器: 1.创建一个自定义类型转换器 ...
- java 使用POI导出百万级数据
先看结果吧,这只是测试其中有很多因数影响了性能. 表总数为:7千多万,测试导出100万 表字段有17个字段 最终excel大小有60多兆 总耗时:126165毫秒 差不多2分多钟 其核心简单来说就是分 ...
- win10家庭版设置移动热点出现“我们无法设置移动热点”
寝室wifi卡到爆炸, 买了一个360随身WiFi,可是360随身WiFi烧坏了 ...然后我就一个星期没玩游戏了 今天本来想开电脑的wifi试一试,结果发现无法设置热点 纳闷了 百度一下,发现都 ...
- 多容器共享volume
目标: pod中 包含两个容器: tomcat和busybox, 设置volume:app-logs, 用于tomcat向其中写日志, busybox读日志文件 apiVersion: apps/v1 ...
- F - Star SPOJ - STARSBC
Fernando won a compass for his birthday, and now his favorite hobby is drawing stars: first, he marks ...
- 从Excel中读取数据并批量写入MySQL数据库(基于MySQLdb)
一.Excel内容如下,现在需要将Excel中的数据全部写入的MySQL数据库中: 二.连接MySQL的第三方库使用的是“MySQLdb”,代码如下: # -*- coding:utf-8 -*-im ...