对两个表的操做 开启事务的注解 在类上标注@EnableTransactionManagement注解
在方法上标注 @Transactional(propagation = Propagation.REQUIRED,rollbackFor=Exception.class)

① 同时删除两张表的记录例子

@Service
@EnableTransactionManagement
public class ApplyServicelmpl implements ApplyService {

        @Resource
	private  ApplyMapper applyMapper;
	
	@Resource
	private  ApplyResMapper  applyResMapper;

        @Override
	@Transactional(propagation = Propagation.REQUIRED,rollbackFor=Exception.class)
	public void deleteApplyById(Integer applyId)throws Exception{
		// TODO Auto-generated method stub
		applyResMapper.deleteByApplyId(applyId);
		applyMapper.deleteApplyById(applyId);
	}

}



②同时添加两张表的记录  事务的管理

@Service
@EnableTransactionManagement
public class ApplyServicelmpl implements ApplyService {
        @Resource
	private  ApplyMapper applyMapper;
	
	@Resource
	private  ApplyResMapper  applyResMapper;

        @Override
	@Transactional(propagation = Propagation.REQUIRED, rollbackFor = Exception.class)
	public void addApply(ApplyBean applyBean)throws Exception {
		// TODO Auto-generated method stub
		applyMapper.addApply(applyBean);
		List<ApplyResBean>  applyResList = applyBean.getApplyResList();
		System.out.println(applyResList.size());
		for(ApplyResBean applyResBean:applyResList){
			applyResBean.setApplyId(applyBean.getId());
		}
		applyResMapper.insertApplyResList(applyResList);
	}

}

使用MySQL命令行窗口来进行数据库的事务操作

MySQL数据库默认事务是自动提交的,也就是发一条SQL数据库就执行一条。如果想将多条SQL放置在一个事务中执行,就必须使用如下语句:

start  transaction
sql1
sql2
commit



当开启事务后(start transaction),无论数据库是否对其中的多条SQL语句是否执行成功,只要没有提交事务(commit),都会将之前执行的SQL进行回滚。使数据回到开启事务之前的值。

在MySQL中,与事务相关的有开启事务(START TRANSACTION),提交事务(COMMIT),回滚事务(ROLLBACK)等等,MySQL命令均以分号结束。

查询MySQL下的所有数据库命令 show  databases;

事务开启后rpc_数据库

使用某个数据库命令 use demotest;

事务开启后rpc_事务开启后rpc_02

查看此数据库下的所有表

事务开启后rpc_MySQL_03

查询某张表下的记录

事务开启后rpc_MySQL_04

假设数据库执行到此发生了错误,我们将MySQL的命令行窗口关闭来代替这样的“错误”:

事务开启后rpc_事务开启后rpc_05

这时如果我们再重新打开MySQL命令行窗口,重新查看用户的金额,发现由于我们开启事务后,并未提交(commit),因此导致事务回滚,之前执行的SQL语句全部不算成功,因此即使数据库可能发生了错误,用户金额还是能由事务保证不出意外:

事务开启后rpc_事务开启后rpc_06

事务开启后rpc_数据库_07

数据库中表的记录被彻底改变了。

通过上面两个例子可以看出,如果我们想将多条SQL作为整体执行,只要有一个条SQL执行失败或者数据库突然出错就回滚到最开始执行之前的状态,使用事务是最好的选择。