当前位置: 首页 > 知识库问答 >
问题:

javax。坚持不懈即使在回滚事务之外,EntityManager也不会在数据库中插入内容

昝卓
2023-03-14

我不明白为什么我的代码像窗帘一样,如果有人能解释一下,那就太棒了。我面临的问题。。。我有两张桌子。方法一开始,我就在“table1”中插入一些东西,插入之后,我开始事务。让我们假设代码流总是到达事务。回滚()。我希望第二个查询被回滚,但不是第一个查询。但在我看来,他们两个都是倒退的。

太长,读不下去了

预期结果:

  • 第一个查询已提交
  • 第二个查询已回滚

当前结果:

  • 第一个查询被回滚
//Relevant imports
import java.sql.PreparedStatement;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.jdbc.Work;

public boolean myMethod(String createdBy) {
        final Long messageId = ((BigInteger) myEntityManager.createNativeQuery("insert into table1(created_by) values (:createdBy) returning id")
                .setParameter("createdBy", createdBy)
                .getSingleResult()).longValue();

        Session session = myEntityManager.unwrap(Session.class);
        Transaction tx = session.beginTransaction();

        session.doWork(new Work() {
            @Override
            public void execute(Connection conn) throws SQLException {

                String sqlInsert = "insert into table2(messageId) values (?)";
                try ( PreparedStatement pstmt = conn.prepareStatement(sqlInsert)) {

                    for (Object[] row : unsentRecords) {
                        pstmt.setLong(1, messageId);
                        pstmt.addBatch();
                    }
                    //Execute batch
                    int[] sqlStatmentsStatuses = pstmt.executeBatch();
                    //check if some statement failed
                    //Let's assume it always fails,just to be explicit
                    boolean somethingWentWrong = atLeastOneFailed(sqlStatmentsStatuses);
                    somethingWentWrong = true;
                    if(somethingWentWrong){
                        tx.rollback();
                    }
                }
            }
        }
    }

注:我不知道如何准确地回答这个问题。因此,如果有人能为这个问题建议一个更好的标题,请把它放在评论中,我会更改它。

共有1个答案

阮轶
2023-03-14

下面是交易#starinTransaction javadoc

Begin a unit of work and return the associated Transaction object. If a new underlying transaction is required, begin the transaction. Otherwise continue the new work in the context of the existing underlying transaction.

它说,如果不可用,创建并开始新的事务。在您的情况下,您已经在执行一个正在启动事务的查询。所以当你说会话时。beginTransaction(),它不是创建新事务,而是返回现有事务,这就是为什么在回滚该事务时,两个查询都会回滚。

 类似资料:
  • 我目前正在使用Spring Boot 2.1.1。发布,Hibernate Envers 5.3.7。最终的 当我为我的用户类查询AuditEntity时,它会抛出javax。坚持不懈EntityNotFoundException表示我的用户记录不存在。然而,在数据库中它确实存在。有人知道为什么吗? 用户实体 在查询审核实体时,属性createByUser updateByUser抛出异常java

  • 我在启动我的web应用程序时遇到了这个错误,我真的不知道问题出在哪里,全速: 组织。springframework。豆。工厂UnsatisfiedPendencyException:创建名为“usuarioController”的bean时出错,该名称在文件[C:\Users\Carlos\eclipsejee workspace.metadata.plugins\org.eclipse.wst.

  • 我有一个问题,这似乎是非常类似于如何创建一个Jandex索引在Quarkus的类在一个外部模块,我仔细地按照所有建议的步骤(jandex maven插件,空beans.xml,索引其他依赖)。 与上述问题的一个明显区别是,quarkus在我的案例中没有找到第三方类,所以我尝试“索引其他依赖项”。然而,javax。坚持不懈AttributeConverter是maven模块javax的一部分。持久性

  • 我有一个Play框架应用程序,我使用的是Hibernate 4.2。5.最终版本(通过Maven依赖关系管理器检索)。我决定升级到Hibernate4.3。0.最后,成功重新编译我的应用程序并运行它。 我得到了下面的例外,并没有能够找出原因。我降级回到4.2.5,这个问题没有发生。然后,我尝试在4.2.5之后的每个最终版本中升级Hibernate。也就是说,我从4.2.5。最终到4.2.6。最后,

  • 创建在类路径资源[ApplicationContext.xml]中定义的名为“sessionFactory”的bean时出错:调用init方法失败;嵌套异常为java。lang.NoSuchMethodError:javax。坚持不懈唯一约束。name()Ljava/lang/String; 这有什么不对吗? 我用的是 有人告诉我这是“hibernate-jpa-2.0-api-1.0.0.jar

  • 我正在开发Spring Boot应用程序,在启动服务器时遇到了这个错误。我不确定是否错误地定义了任何注释或缺少任何依赖项。任何帮助都将不胜感激。 主要类: UserService类: UserDAO类: @repository公共类UserDAO实现IUserDAO{ Build.gradle: 错误消息: 我看到了所有相关的答案,并尝试实现这些建议,如添加依赖项、在主类中添加符号等。但它显示了相