Spring的事务经常会有这样的配置:
<tx:method name="search*" read-only="true" />
或
@Transactional(readOnly = true)
概念:从这一点设置的时间点开始(时间点a)到这个事务结束的过程中,其他事务所提交的数据,该事务将看不见!(查询中不会出现别人在时间点a之后提交的数据)
在将事务设置成只读后,相当于将数据库设置成只读数据库,此时若要进行写的操作,会出现错误
“只读事务”并不是一个强制选项,它只是一个“暗示”,提示数据库驱动程序和数据库系统,这个事务并不包含更改数据的操作, 那么JDBC驱动程序和数据库就有可能根据这种情况对该事务进行一些特定的优化, 比方说不安排相应的数据库锁,以减轻事务对数据库的压力,毕竟事务也是要消耗数据库的资源的。
本文深入探讨了Spring框架中事务的只读属性配置,解释了如何通过<tx:method>或@Transactional注解设置事务为只读,以及这样做对数据库性能优化的影响。在只读事务中,数据库驱动程序可能不会安排相应的锁,从而减轻事务对数据库的压力。
764

被折叠的 条评论
为什么被折叠?



