就是只能查看,不能进行修改和添加
您好
如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持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中设置只读事务是利用上面两种方式(根据实际情况)
在将事务设置成只读后,相当于将数据库设置成只读数据库,此时若要进行写的操作,会出现错误。
希望对你有帮助。
用户登录
还没有账号?立即注册
用户注册
投稿取消
文章分类: |
|
还能输入300字
上传中....