码迷,mamicode.com
首页 > 数据库 > 详细

java.sql.SQLException:连接是只读的。不允许导致数据修改的查询

时间:2019-12-07 12:15:03      阅读:266      评论:0      收藏:0      [点我收藏+]

标签:span   div   实现类   允许   事务   技术   图片   code   session   

技术图片

我的项目中

技术图片 

 

 service的实现类少了写一个注解   : 只读事务(@Transactional(readOnly = true)

应用场合:

       如果你一次执行单条查询语句,则没有必要启用事务支持,数据库默认支持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中设置只读事务是利用上面两种方式

 

  在将事务设置成只读后,相当于将数据库设置成只读数据库,此时若要进行写的操作,会出现错误

 

 

 

 

技术图片

 

 

 改:

 

 

技术图片

 

 

 

 

 

 

 

 

 

java.sql.SQLException:连接是只读的。不允许导致数据修改的查询

标签:span   div   实现类   允许   事务   技术   图片   code   session   

原文地址:https://www.cnblogs.com/idlql/p/12001185.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!