Spring事务初学

Spring事务初学

Spring使用注解@Transactional来管理事务

1. propagation属性:事务的传播行为(7种)

	Propagetion.REQUIRED :默认使用,如果有事务在运行,当前的方法就在这个事务内运行。否则,就启动一个新的事务,并在自己的事务内运行。
	Propagation.REQUIRES_NEW :当前的方法必须启动新的事务,并在它自己的事务内运行,如果有事务正在运行,应该将它挂起。
	Propagation.SUPPORTS :如果有事务在运行,当前的方法就在这个事务内运行。否则它可以不运行在事务中。
	Propagation.NOTSUPPORT :当前的方法不应该运行在事务中,如果有运行的事务,将它挂起。
	Propagation.MANDATORY :当前的方法必须运行在事务内部,如果没有正在运行的事务,就排除异常。
	Propagation.NEVER :当前的方法不应该运行在事务中,如果有运行的事务,就抛出异常。
	Propagation.NESTED : 如果有事务正在运行,当前的方法就应该在这个事务的嵌套事务内运行。否则,就启动一个新的事务,并在它自己的事务内运行。

2. isolation属性 :设置事务的隔离级别

	(READ_UNCOMMITTED)读未提交(脏读):读取了未提交事务或者回滚了的数据。
	(READ_COMMITTED)读已提交(不可重复读) :读取的是已经提交的事务,并发时会造成两次读取的数据不一致。
	(REPEATABLE_READ)可重复读(幻读) :在读取的数据的时候,别人不能对这些数据进行操作。但是可以新增数据,所以会造成幻读的情况。
	(SERIALIZABLE)可串行化 :效率低,性能差。
  • Oracle数据库支持读已提交,串行化。默认事务隔离级别为读已提交。
  • MySQL数据库支持四种事务的隔离级别,默认为可重复度。
脏读不可重复读幻读
读未提交
读已提交×
可重复读××
串行化×××

3.设置事务是否回滚

	rollbackFor :指定遇到时必须进行回滚的异常类型,可以为多个。默认所有异常都会触发回滚。
	noRollbackFor :指定遇到时不回滚的异常类型,可以为多个。

4.timeout属性 :设置事务强制回滚的超时时间,已秒为单位

	默认与数据库的超时时间相同。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值