- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我用 @Transactional
注释了我的服务方法readonly=true
.
因为那个 spring/hibernate 没有调用 jdbc 连接驱动程序的 setReadonly 方法。我能做些什么?
因为我将使用主从复制,并且 jdbc 池使用连接上的只读标志将查询路由到主服务器或从服务器。
最佳答案
首先,当您的 PU 事务模式为 RESOURCE_LOCAL 时,您应该只为 JDBC 连接设置 readOnly 标志。如果它是 JTA,那么您不能更改该设置,因为您不会为事务中的每个 jdbc 调用获得相同的 jdbc 连接实例(JTA - 而不是 Hibernate - 将确保事务行为)。当它是 LOCAL 时,Hibernate 在第一次需要它时打开一个 jdbc 连接,并在事务期间保留它。
1. JPA
如果您将 JPA 与 Hibernate 作为提供程序一起使用,则可以通过以下方式添加此额外行为
为 EMF 定义提供您自己的 JpaDialect 实现。使用 Hibernate 时,通常会注入(inject)一个 HibernateJpaDialect。
JpaDialect 接口(interface)有一个 getJdbcConnection(em, readOnly)
返回实际 JDBC 连接的句柄的方法。此方法在事务开始时由 JpaTransactionManager 调用。默认情况下,由于这种 JTA/RESOURCE_LOCAL 对偶性,HibernateJpaDialect 不会更改返回连接上的只读设置,但如果您只运行本地事务,则可以这样做。
这是实现您的目标的此类 JpaDialect 的实现:
ResourceLocalReadOnlyAwareHibernateJpaDialect
public class ResourceLocalReadOnlyAwareHibernateJpaDialect extends HibernateJpaDialect {
public ConnectionHandle getJdbcConnection(EntityManager entityManager, boolean readOnly) throws PersistenceException, SQLException {
Session session = getSession(entityManager);
return new HibernateReadOnlyAwareConnectionHandle(session, readOnly);
}
// this is similar to spring's HibernateJpaDialect own internal class,
// except for the readonly flags.
private static class HibernateReadOnlyAwareConnectionHandleimplements ConnectionHandle {
private final Session session;
private final boolean readOnly;
private static volatile Method connectionMethod;
public HibernateConnectionHandle(Session session, boolean readOnly) {
this.session = session;
this.readOnly = readOnly;
}
public Connection getConnection() {
try {
if (connectionMethod == null) {
// reflective lookup to bridge between Hibernate 3.x and 4.x
connectionMethod = this.session.getClass().getMethod("connection");
}
Connection con = (Connection) ReflectionUtils.invokeMethod(connectionMethod, this.session);
con.setReadOnly(this.readOnly);
return con;
} catch (NoSuchMethodException ex) {
throw new IllegalStateException("Cannot find connection() method on Hibernate session", ex);
}
}
public void releaseConnection(Connection con) { // #1
con.setReadOnly(false);
JdbcUtils.closeConnection(con);
}
}
}
connection.close()
调用,只是释放与池的连接)。不太确定是什么触发了此方法调用,但在与更改位置相同的类中重置 readOnly 标志看起来是合法的。
HibernateTransactionManager.prepareConnection
保持真实。
HibernateTransactionManager.isSameConnectionForEntireSession()
:如果方法返回true,将调用connection.setReadOnly(),因此一切正常。
hibernate.transaction.auto_close_session=true
,这是 Hibernate 3.1 之前的默认值),或者覆盖
HibernateTransactionManager.isSameConnectionForEntireSession()
为了始终返回 true (这在 HibernateTransactionManager 注释方面被认为是安全的)。两者都是“高级调整”,但应该是安全的 AFAIK。实际上,我认为
HibernateTransactionManager.isSameConnectionForEntireSession()
ON_CLOSE
都应更改为返回 true和 AFTER_TRANSACTION Release模式:关于 HibernateTransactionManager,在事务完成后无论如何都会进行清理,因此不会改变 Hibernate 行为。
关于Spring:@Transactional with readonly=true 不调用 conn.setReadOnly(true),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10271624/
我有一个只读的文本框,但想回发它的值。之前我将代码设置为: /asp:TextBox> 它不工作。我删除了 ReadOnly="true" 并在代码中添加了以下行 txtContractStartDa
一些背景 因此,我正在完成一个 Web 应用程序的一些增强功能,该应用程序可以对数据进行一些自动插值。用户填写了一些文本框,它们之间的其他文本框具有自动计算的值。接收自动计算值的文本框必须是只读的,以
我刚刚审查了一些代码,注意到有人将成员标记为 readonly private。这与 private readonly 有任何不同吗? 例子: readonly private MyClass myI
我刚刚被告知 readonly ref readonly 现在是有效的 C#,我可以清楚地看到它作为面试问题的用途,但除此之外,它什么时候可以用于现实生活? 最佳答案 当您有一个可变结构时,您希望其中
当我使用以下命令运行我的Reactjs + ElectronJS应用程序时,它可以很好地运行: yarn start 。 当我尝试使用以下命令生成该错误时: yarn build 。 我不明白这是怎么
例子1 private const string _DefaultIconPath = _IconsPath + "default.ico"; private const string _IconsP
尝试访问 RecipeList.js 和 Recipe.js 的 .props 时出现语法错误。 这是 Recipe.js 的代码示例: import React, {Component} from
我是 Vue 新手。我正在尝试开发一个聊天应用程序,其中好友列表将显示在左侧菜单上,聊天框将显示在正文中。我正在使用 ajax 调用加载好友列表,并根据好友 ID 路由到聊天框。这是代码示例。
我是 SharePoint 的初学者开发人员,我一直使用 Google map 。我安装了 google-maps-react 但有一个错误告诉我。我不知道如何解决它...请让我知道这个解决方案...
我不确定我是否理解 IE 在我正在使用的脚本中的行为。这是我正在使用的脚本的一部分,它似乎在 Chrome 中运行良好 $(document).keydown(function (event) {
我对原生 react 完全陌生。 我有以下组件: 播放列表: export default class Playlists extends Component { playlists = [
所以我正在使用 MVC3 生成一个文本区域元素。我使用以下标记生成我的元素: model.Description, new { value=Model.Description, @class="re
我有一个从 php 文件创建的表单,以及一个具有只读属性的文本字段,在单击编辑按钮时(编辑按钮也在创建输入字段期间创建),我希望所述字段是可编辑,我该怎么做? value= readOnly>
我正在尝试输入组件的属性并同时使用 URL 参数。我收到以下错误: Property 'match' does not exist on type 'Readonly & Readonly' 这是我的
这个问题在这里已经有了答案: Array.IsReadOnly inconsistent depending on interface implementation (4 个答案) 关闭 8 年前。
根据文档 ( here ),Google 提供了一些相同的范围: https://www.googleapis.com/auth/calendar读/写访问到日历 https://www.google
我使用的是JAWS v2023.2212.23,我有一个div容器,里面有段落和列表。我的要求是,当我专注于div容器时,JAWS应该读取整个块。。对于演示角色,它将只读第一段。。谁能帮我理解所有咏叹
我有一个单选按钮控件,其中有两个项目。 Add A Delete D 我想在条件 X 上仅禁
一、Reactive api 下面我们可以一个例子 如图所示,当我们点击button按钮的时候,是没有响应式效果的,此时我们需要reactive api。 那么这是什么原因呢?为什么就可以变成响应式的
我正在寻找一种在ng-readonly语句中调节ng-if的方法..我尝试了几种方法,这是我的最新建议。 ng-if="note.owner_image === user.image " ng-re
我是一名优秀的程序员,十分优秀!