Antrag (アプリケーション) と Anlage (施設) の 2 つのオブジェクトがあります。複数施設の申し込みが可能です。アプリケーションは DAO に直接永続化されます。ファシリティはカスケード経由で永続化されます。
@Entity
@Table(name = "EEG_ANTRAG")
public class Antrag implements Serializable {
private static final long serialVersionUID = -2440344011443487714L;
@Id
@Column(name = "ANT_ID", nullable = false)
@SequenceGenerator(name = "sequenceGeneratorAntrag", sequenceName = "EEG_ANTRAG_SEQ", allocationSize = 1)
@GeneratedValue(generator = "sequenceGeneratorAntrag")
@Getter @Setter private Long id;
@OneToMany(mappedBy = "antrag", cascade = { CascadeType.ALL }, orphanRemoval = true)
@OrderBy("id ASC")
@Getter private List<Anlage> anlageList = new ArrayList<Anlage>();
public Anlage addAnlage(Anlage anlage)
anlageList.add(anlage);
anlage.setApplication(this);
return anlage;
}
/* some more simple attributes; just Strings, boolean, .. */
}
@Entity
@Table(name = "EEG_ANLAGE")
public class Anlage implements Serializable {
private static final long serialVersionUID = -3940344011443487741L;
@Id
@Column(name = "ANL_ID")
@SequenceGenerator(name = "sequenceGeneratorAnlage", sequenceName = "EEG_ANLAGE_SEQ", allocationSize = 1)
@GeneratedValue(generator = "sequenceGeneratorAnlage")
@Getter @Setter private Long id;
@ManyToOne
@JoinColumn(name = "ANL_ANT_ID")
@Getter @Setter private Antrag antrag;
/* some more simple attributes; just Strings, boolean, .. */
}
@Stateless
public class AntragDaoBean implements AntragDaoLocal {
@PersistenceContext(unitName = "ejb-model")
private EntityManager em;
@Override
public void persistAntrag(Antrag antrag) {
em.persist(antrag);
}
}
機能の挿入時にエラーが発生した場合 (エンティティ内の列名のスペルが間違っているなど)、例外がスローされます。スタック トレースは、ロールバックが実行されたことを示します。問題は、アプリケーションがまだ永続化されていることです。アプリケーションの挿入もロールバックされるべきではありませんか? EclipseLink 2.4.1 を使用しています。EclipseLink のデバッグ出力には、すべての挿入が 1 つのトランザクションで実行されることが示されています。データベースは Oracle 11g です。トランザクション動作に対する私の予想は間違っていますか? 必要な動作を取得するにはどうすればよいですか?
/* shortened exemplary stacktrace for rollback */
EvaluationException:
javax.faces.component.MethodBindingMethodExpressionAdapter.invoke(MethodBindingMethodExpressionAdapter.java:101)
EJBTransactionRolledbackException:
org.jboss.as.ejb3.tx.CMTTxInterceptor.handleEndTransactionException(CMTTxInterceptor.java:115)
RollbackException:
com.arjuna.ats.internal.jta.transaction.arjunacore.TransactionImple.commitAndDisassociate(TransactionImple.java:1177)
DatabaseException:
org.eclipse.persistence.exceptions.DatabaseException.sqlException(DatabaseException.java:324)
SQLSyntaxErrorException:
oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:445)