只读事务(@Transactional(readOnly = true))的一些概念
来源:互联网 发布:淘宝买的酒是真的吗 编辑:程序博客网 时间:2024/05/19 16:47
念:从这一点设置的时间点开始(时间点a)到这个事务结束的过程中,其他事务所提交的数据,该事务将看不见!(查询中不会出现别人在时间点a之后提交的数据)
应用场合:
如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持SQL执行期间的读一致性;
如果你一次执行多条查询语句,例如统计查询,报表查询,在这种场景下,多条查询SQL必须保证整体的读一致性,否则,在前条SQL查询之后,后条SQL查询之前,数据被其他用户改变,则该次整体的统计查询将会出现读数据不一致的状态,此时,应该启用事务支持。
【注意是一次执行多次查询来统计某些信息,这时为了保证数据整体的一致性,要用只读事务】
怎样设置:
对于只读查询,可以指定事务类型为readonly,即只读事务。
由于只读事务不存在数据的修改,因此数据库将会为只读事务提供一些优化手段,例如Oracle对于只读事务,不启动回滚段,不记录回滚log。
(1)在JDBC中,指定只读事务的办法为: connection.setReadOnly(true);
(2)在hibernate中,指定只读事务的办法为: session.setFlushMode(FlushMode.NEVER);
此时,Hibernate也会为只读事务提供Session方面的一些优化手段
(3)在spring的Hibernate封装中,指定只读事务的办法为: bean配置文件中,prop属性增加“readOnly”
或者用注解方式@Transactional(readOnly=true)
【 if the transaction is marked as read-only, Spring will set the Hibernate Session’s flush mode to FLUSH_NEVER,
and will set the JDBC transaction to read-only】也就是说在Spring中设置只读事务是利用上面两种方式
- 只读事务(@Transactional(readOnly = true))的一些概念
- 只读事务(@Transactional(readOnly = true))的一些概念
- Spring read-only="true" 只读事务的一些概念
- Spring read-only="true" 只读事务的一些概念
- @Transactional(readOnly = true)无法控制事物只读
- [转载]Spring read-only="true" 只读事务的一些概念
- 只读事务的一些概念
- 只读事务的一些概念
- 只读事务的一些概念
- Spring 注解@Transactional readOnly=true
- Spring 注解@Transactional readOnly=true
- Spring 注解@Transactional readOnly=true .
- Spring 注解@Transactional readOnly=true
- Spring 注解@Transactional readOnly=true
- Spring 注解@Transactional readOnly=true
- spring事务定义中,@Transactional(readOnly = true, propagation = Propagation.NOT_SUPPORTED) 这样定义有问题吗?
- springmvc修改时报数据库为只读readOnly = true
- @Transactional的readOnly、timeout
- Java9正则表达式新特性
- Jetty之Debug-yellowcong
- C++字符串操作详解
- 机器学习模型性能度量
- 二叉树中序遍历
- 只读事务(@Transactional(readOnly = true))的一些概念
- Android 快速开发系列 ORMLite 框架最佳实践
- Adaptive Reference Sample Smoothing(RSAF)
- Java 处理Oracle数据对于小于1的小数,小数点前面的0是不显示的。
- Python 使用期物处理并发
- Java面试的战地笔记
- 剑指offer(28)—数组中出现次数超过一半的数字
- 关闭当前页面,返回父页面并刷新
- ionic2开发(二)在TypeScript中引用第三方js库