首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

spring-只读属性read-only="true"

2013-12-19 
spring-只读属性read-onlytrue1.如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持SQ

spring-只读属性read-only="true"

1.如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持SQL执行期间的读一致性; 如果你一次执行多条查询语句,例如统计查询,报表查询,在这种场景下,多条查询SQL必须保证整体的读一致性,否则,在前条SQL查询之后,后条SQL查询之前,数据被其他用户改变,则该次整体的统计查询将会出现读数据不一致的状态,此时,应该启用事务支持read-only="true"表示该事务为只读事务,比如上面说的多条查询的这种情况可以使用只读事务,由于只读事务不存在数据的修改,因此数据库将会为只读事务提供一些优化手段,例如Oracle对于只读事务,不启动回滚段,不记录回滚log。(1)在JDBC中,指定只读事务的办法为: connection.setReadOnly(true);(2)在Hibernate中,指定只读事务的办法为: session.setFlushMode(FlushMode.NEVER); 此时,Hibernate也会为只读事务提供Session方面的一些优化手段(3)在Spring的Hibernate封装中,指定只读事务的办法为: bean配置文件中,prop属性增加“read-Only”或者用注解方式@Transactional(readOnly=true)Spring中设置只读事务是利用上面两种方式(根据实际情况)在将事务设置成只读后,相当于将数据库设置成只读数据库,此时若要进行写的操作,会出现错误。希望对你有帮助。2.“只读事务”并不是一个强制选项,它只是一个“暗示”,提示数据库驱动程序和数据库系统,这个事务并不包含更改数据的操作,那么JDBC驱动程序和数据库就有可能根据这种情况对该事务进行一些特定的优化,比方说不安排相应的数据库锁,以减轻事务对数据库的压力,毕竟事务也是要消耗数据库的资源的。 但是你非要在“只读事务”里面修改数据,也并非不可以,只不过对于数据一致性的保护不像“读写事务”那样保险而已。 因此,“只读事务”仅仅是一个性能优化的推荐配置而已,并非强制你要这样做不可

热点排行