您的位置:首页 > 编程语言 > Java开发

spring中@Transactional对于事务异常的处理

2012-08-12 16:57 423 查看
spring对于事务异常的处理



//unchecked 运行期Exception spring默认会进行事务回滚 比如:RuntimeException



//checked 用户Exception spring默认不会进行事务回滚 比如:Exception

如何改变spring的这种默认事务行为?可以通过在方法上

添加@Transactional(noRollbackFor=RuntimeException.class)让spring对于RuntimeException不回滚事务

添加@Transactional(RollbackFor=Exception.class)让spring对于Exception进行事务的回滚

[b]@Transactional(propagation=Propagation.REQUIRED[/b][b])[/b]

required为默认行为













如果只是内部的try/catch块出现异常只会导致内部try/catch块的事务的回滚,则内部try/catch块的操作不会被执行,但是另外的操作任然会执行。

而如果外部出现异常则会导致整个事务的回滚,那么所有的操作都不会被执行,即使内部try/catch块没有出现异常。

[b]@Transactional(readOnly=true)[/b]

[b]只读属性,不允许进行更新操作,可以提高效率[/b]

[b]@Transactional(timeout=30)[/b]

[b]超时,默认为30秒

[/b]

[b][b][b]@Transactional(isolation=Isolation.REPEATABLE_READ)[/b]

[/b][/b]

[b]事务隔离级别[/b]

[b]

[/b]

[b]MYSQL默认为第三种级别[b][b]REPEATABLE_READ[/b][/b][/b]

[b]MSSQLSERVER2000默认为第二种级别READ_COMMITTED[/b]

[b][b]MSSQLSERVER2005可以设为第二三种级别而且效率不会比第二种级别差[/b][/b]

[b][b]级别越高,效率越低[/b]

[/b]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: