Spring事务中的readonly

来源:https://www.cnblogs.com/straybirds/p/9147892.htmlhtml

Spring的事务常常会有这样的配置:数据库

<tx:method name="search*" read-only="true" /> 

或者这样的注记:优化

@Transactional(readOnly = true)

缘由:spa

“只读事务”并非一个强制选项,它只是一个“暗示”,提示数据库驱动程序和数据库系统,这个事务并不包含更改数据的操做,
那么JDBC驱动程序和数据库就有可能根据这种状况对该事务进行一些特定的优化,
比方说不安排相应的数据库锁,以减轻事务对数据库的压力,毕竟事务也是要消耗数据库的资源的。
1 readonly并非全部数据库都支持的,不一样的数据库下会有不一样的结果。
2 设置了readonly后,connection都会被赋予readonly,效果取决于数据库的实现。
3 在ORM中,设置了readonly会赋予一些额外的优化,例如在Hibernate中,会被禁止flush等。
相关文章
相关标签/搜索