spring boot 数据库-事务处理

2017-07-15  本文已影响814人  逗比punk
一、事务有四个特性:ACID

二、传播行为

当事务方法被另一个事务方法调用时,必须指定事务应该如何传播。例如:方法可能继续在现有事务中运
行,也可能开启一个新事务,并在自己的事务中运行。
Spring 定义了七种传播行为:

三、隔离级别

隔离级别定义了一个事务可能受其他并发事务影响的程度。
ISOLATION_DEFAULT 使用后端数据库默认的隔离级别,Spring默认使用,mysql默认的隔离级别为:

四、属性说明 @Transactional

a、isolation:用于指定事务的隔离级别。默认为底层事务的隔离级别。
b、noRollbackFor:指定遇到指定异常时强制不回滚事务。
c、noRollbackForClassName:指定遇到指定多个异常时强制不回滚事务。该属性可以指定多个异常类 名。
d、propagation:指定事务的传播属性。
e、readOnly:指定事务是否只读。表示这个事务只读取数据但不更新数据,这样可以帮助数据库引擎优 化事务。若真的是一个只读取的数据库应设置 readOnly=true
f、rollbackFor:指定遇到指定异常时强制回滚事务。
g、rollbackForClassName:指定遇到指定多个异常时强制回滚事务。该属性可以指定多个异常类名。
h、timeout:指定事务的超时时长。
注意:

1.mysql 为例,存储引擎不能使用 MyISAM,应该使用 InnoDB
实现代码

@Service
public class UserService { 
@Autowired
private RoncooUserDao roncooUserDao;
 @Autowired
private RoncooUserLogDao roncooUserLogDao;

/**
* 用户注册 *
* @return
*/
@Transactional
public String register(String name, String ip) {
// 1.添加用户
RoncooUser roncooUser = new RoncooUser(); roncooUser.setName(name);
roncooUser.setCreateTime(new Date()); roncooUserDao.insert(roncooUser);
// 测试使用
boolean flag = true; 
if (flag) {
throw new RuntimeException(); 
}
// 2.添加注册日志
RoncooUserLog roncooUserLog = new RoncooUserLog(); roncooUserLog.setUserName(name); roncooUserLog.setUserIp(ip); 
roncooUserLog.setCreateTime(new Date()); roncooUserLogDao.save(roncooUserLog);
return "success"; }
}
测试
@Autowired
private UserService userService;
@Test
public void register() {
String result = userService.register("无境", "192.168.1.1");
     System.out.println(result);
}
上一篇 下一篇

猜你喜欢

热点阅读