问题描述
假设有三张表:学生表,课程表和教师表;
现在,一个学生要选一门课,先将此课写到学生表中,再将任教老师写入。
但存入课程到学生表成功后,程序出错中断了,后边的教师没有写入,那么就只成功了一半。比如银行用户取钱时,程序将钱扣掉后点钱机出现问题,那么取钱中断程序卡住没有成功,用户既没有得到钱,账户又扣掉了钱。
解决
利用事务
声明式事务管理 @Transactional
注意:
1)接口实现类或接口实现方法上,而不是接口类中。
2)访问权限:public 的方法才起作用。@Transactional 注解应该只被应用到 public 方法上,这是由 Spring AOP 的本质决定的。
@Transactional(rollbackFor = Exception.class)
public String saveIt(String teacherName, String courseName){
Student student = new Student();
// 第一步存教师名
student.setTeacherName(teacherName);
// 第二步存课程名
student.setCourseName(courseName);
save(student);
}
即使存完第一步程序终止,这样也能事务回滚,回到最初状态。
一般用于连续存取操作。