事务参数,也就是事务属性,也就是事务的特有性质。
事务的参数定义是在接口 TransactionDefinition 中定义的。
首先是隔离级别(isolation),隔离级别,也就是一个事务与其他并发事务之间的数据共享程度的级别。
TransactionDefinition有如下五个定义:
// 使用数据库默认的级别
ISOLATION_DEFAULT
//只能读取已经提交的数据,这样可以防止脏读,但是可能会发生不可重复读和幻读
ISOLATION_READ_COMMITTED
//可以读取尚未提交的数据。这样就有可能发生脏读、不可重复读、幻读
ISOLATION_READ_UNCOMMITED
//可以做到读取同一字段的数据都是一致的,这样就可以防止脏读和不可重复读
ISOLATION_REPEATABLE_READ
//符合ACID,也就是事务的完整性,定义了这一个隔离级别,不会发生什么脏读、不可重复读、幻读等
//但是相应的是以性能为代价的。
ISOLATION_SERIALIZABLE
然后就是传播属性了。传播属性,也就是定义事务的边界问题。
TransactionDefinition定义了7个传播属性,如下:
//顾名思义,强制的,也就是说,当前方法必须在事务中,如果不在事务中,就会抛出异常
PROPAGATION_MANDATORY
//支持嵌套事务,也就是事务中再加一个事务。
PROPAGATION_NESTED
//从不事务,如果在事务中运行,就会抛出异常
PROPAGATION_NEVER
//不支持异常,如果在事务中运行,那么会被挂起
PROPAGATION_NOT_SUPPORTED
//要求事务,必须在事务中运行,如果没有事务,就新建一个事务
PROPAGATION_REQUIRED
//要求新事物,不管什么情况,都新建一个事务
PROPAGATION_REQUIRES_NEW
//支持事务,有事务就用,没有事务就不用。不会自己去新建事务
PROPAGATION_SUPPORTS
此外,TransactionDefinition还有一个字段:TIMEOUT_DEFAULT
这个就是控制事务的超时时间,规定事务必须在多长时间内完成。
还有一个 readyOnly选项,TransactionDefinition定义了一个方法:isReadyOnly。据说如果是 radyonly,事务就会进行一定的优化,使得事务是只读的。