[size=medium]
required 业务方法需要在一个事务中运行,如归哦方法运行时,已经处在一个事务中,那么加入到该事物,否则为自己创建一个新的事务。
not_support 声明方法不需要事务,如果方法没有关联一个事务,容器不会为他开启事务,如果方法在一个事务中被调用,该事物会被挂起,在方法调用结束后,原先的事务便会恢复执行。
requireshew 属性表明不管是否存在事务,业务方法总会为自己发起一个新的事务,如果方法已经在一个事务当中,则原有事务会被挂起,新的事务会被创建,直到方法执行结束,新事物才算结束,原先的事务才会被恢复执行。
mandatory 该属性指定业务方法只能在一个已经存在的事务中执行,业务方法不能发起自己的事务,如果业务方法没有在事务的环境下调用,容器就会抛出例外。
support 这一事务属性表明,如果业务方法在某个事务范围内被调用,则方法成为该事物的一部分。如果业务方法在事务范围外被调用,则方法在没有事务的环境下执行。
naver 指定业务方法绝对不能在事务范围内执行,如果业务方法在某个事务中执行,容器会抛出例外,只有业务方法没有关联人和事务,才能正常执行。
以上的事务传播属性 是 spring 借鉴 ejb 框架得来,下面一条是spring 特有的事务传播属性。
nested 如果一个活动的事务存在,则运行子啊一个嵌套的事务中,如果没有活动的事务,则按照required属性执行,她使用了一个单独的事务,这个事务拥有多个可以回滚的保存点,内部事务的回滚不会对外部事务造成影响。她只会对DataSourceTransactionManager事务管理器起作用。
事务也可以设置 只读 和 超时 属性 或者 数据库的隔离级别属性。
[/size]
[size=medium]
通常 读者看到的博客当中 所说的 事务隔离并没有很清楚的说明,这里所说的 spring 的事务隔离级别是指 数据库系统提供的 事务隔离级别。
read uncommited 读取未提交数据(会出现脏读,不可重复读和幻读)
read commited 读取已经提交的数据(会出现不可重复读和幻读)
repeatable read 可重复读(会出现幻读)
serializable 串行化
serializable 的隔离级别最高,read Uncommited隔离级别最低,大部分数据库的隔离级别是 read commited .隔离级别越高,对并发的影响越大。
[/size]
required 业务方法需要在一个事务中运行,如归哦方法运行时,已经处在一个事务中,那么加入到该事物,否则为自己创建一个新的事务。
not_support 声明方法不需要事务,如果方法没有关联一个事务,容器不会为他开启事务,如果方法在一个事务中被调用,该事物会被挂起,在方法调用结束后,原先的事务便会恢复执行。
requireshew 属性表明不管是否存在事务,业务方法总会为自己发起一个新的事务,如果方法已经在一个事务当中,则原有事务会被挂起,新的事务会被创建,直到方法执行结束,新事物才算结束,原先的事务才会被恢复执行。
mandatory 该属性指定业务方法只能在一个已经存在的事务中执行,业务方法不能发起自己的事务,如果业务方法没有在事务的环境下调用,容器就会抛出例外。
support 这一事务属性表明,如果业务方法在某个事务范围内被调用,则方法成为该事物的一部分。如果业务方法在事务范围外被调用,则方法在没有事务的环境下执行。
naver 指定业务方法绝对不能在事务范围内执行,如果业务方法在某个事务中执行,容器会抛出例外,只有业务方法没有关联人和事务,才能正常执行。
以上的事务传播属性 是 spring 借鉴 ejb 框架得来,下面一条是spring 特有的事务传播属性。
nested 如果一个活动的事务存在,则运行子啊一个嵌套的事务中,如果没有活动的事务,则按照required属性执行,她使用了一个单独的事务,这个事务拥有多个可以回滚的保存点,内部事务的回滚不会对外部事务造成影响。她只会对DataSourceTransactionManager事务管理器起作用。
事务也可以设置 只读 和 超时 属性 或者 数据库的隔离级别属性。
[/size]
@Transactional(propagation=Propagation.NOT_SUPPORT,readOnly=true,)
[size=medium]
通常 读者看到的博客当中 所说的 事务隔离并没有很清楚的说明,这里所说的 spring 的事务隔离级别是指 数据库系统提供的 事务隔离级别。
read uncommited 读取未提交数据(会出现脏读,不可重复读和幻读)
read commited 读取已经提交的数据(会出现不可重复读和幻读)
repeatable read 可重复读(会出现幻读)
serializable 串行化
serializable 的隔离级别最高,read Uncommited隔离级别最低,大部分数据库的隔离级别是 read commited .隔离级别越高,对并发的影响越大。
[/size]