事务优化

  1. 在实际开发中, 为了提升性能, 事务会以较低的隔离级别运行

  2. 设置回滚事务属性

    默认情况下只有未检查异常(RuntimeException和Error类型的异常)会导致事务回滚. 而受检查异常不会.
事务的回滚规则可以通过 @Transactional 注解的 rollbackFor 和 noRollbackFor 属性来定义.

这两个属性被声明为 Class[] 类型的, 因此可以为这两个属性指定多个异常类.
rollbackFor:  遇到时必须进行回滚
noRollbackFor: 一组异常类,遇到时必须不回滚

    3.超时和只读属性

    由于事务可以在行和表上获得锁,  因此长事务会占用资源, 并对整体性能产生影响.
如果一个事物只读取数据但不做修改, 数据库引擎可以对这个事务进行优化.
超时事务属性: 事务在强制回滚之前可以保持多久. 这样可以防止长期运行的事务占用资源.
只读事务属性: 表示这个事务只读取数据但不更新数据, 这样可以帮助数据库引擎优化事务.

超时和只读属性可以在 @Transactional 注解中定义.超时属性以秒为单位来计算.readOnly,timeout

你可能感兴趣的:(事务优化)