gpt4 book ai didi

java - 在 Hibernate 中,两个实体如何与第三个实体具有多对多的单向关系?

转载 作者:行者123 更新时间:2023-11-30 07:02:04 25 4
gpt4 key购买 nike

使用部署在 Jboss 4 上的现有工作 Hibernate 3 代码,现在我尝试将其部署在 Wildfly 10 (Hibernate 5) 上。在部署时完成的验证期间,将显示以下消息:

org.hibernate.persister.walking.spi.WalkingException: Association has already been visited: AssociationKey(table=pur_DemandDtl_DemandHeader, columns={DemandEventHeaderTRIk})

(我将在下面显示完整的堆栈)

首先我总结一下:涉及3个类。在 2 个类中,有一个成员集注释为 ManyToMany,并且它是单向的。该集合有第三类成员。

有 3 个表对应 3 个类中的每一个。此外还有第四个表代表两个关联。第 4 个表有 3 列。每一列对应于一个表。显然,在每一行中,与两个表关联的两列之一具有空值。

我几乎没有使用 Hibernate 的经验,但看起来每个关系的定义都与我见过的所有示例中的完全一样。我脑子里唯一的问题是:1)我是否必须做其他事情,因为有两个表与第三个表有关系? 2)将两个关联保存在同一个关联表中是否合法? 3)前2个类的层次结构有问题吗?

好的,现在我将展示一些代码。我将省略一些细节,并在需要时添加。

前 2 个类是 PromoDtl 和 ReserveDtl。它们共享一个公共(public)父类(super class) PromoReserveDtl,并且每个都与第三类 DemandEventHeaderTriggerRecord 具有单向 ManyToMany 关系。

@MappedSuperclass
public abstract class PromoReserveDtl implements Serializable,Comparable<PromoReserveDtl>{

private Integer promoReserveDtlIk;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "PromoReserveDtlIk")
public Integer getPromoReserveDtlIk() {
return promoReserveDtlIk;
}
protected Set<DemandEventHeaderTriggerRecord> demandEventHeaderTriggerRecord = new HashSet<DemandEventHeaderTriggerRecord>();
public void setDemandEventHeaderTriggerRecord(Set<DemandEventHeaderTriggerRecord> demandEventHeaderTriggerRecord) {
this.demandEventHeaderTriggerRecord = demandEventHeaderTriggerRecord;
}
// other stuff
}

@Entity
@Table(name="pur_PromoDtl")
public class PromoDtl extends PromoReserveDtl implements Serializable{
@ManyToMany(fetch = FetchType.EAGER,cascade = { CascadeType.ALL })
@JoinTable(name="pur_DemandDtl_DemandHeader",
joinColumns=@JoinColumn(name="PromoDtlIk"),
inverseJoinColumns=@JoinColumn(name="DemandEventHeaderTRIk"))
public Set<DemandEventHeaderTriggerRecord> getDemandEventHeaderTriggerRecord() {
return demandEventHeaderTriggerRecord;
}
// other stuff
}

@Entity
@Table(name="pur_ReserveDtl")
public class ReserveDtl extends PromoReserveDtl implements Serializable {
@ManyToMany(fetch = FetchType.EAGER,cascade = { CascadeType.ALL })
@JoinTable(name="pur_DemandDtl_DemandHeader",
joinColumns=@JoinColumn(name="ReserveDtlIk"),
inverseJoinColumns=@JoinColumn(name="DemandEventHeaderTRIk"))
public Set<DemandEventHeaderTriggerRecord> getDemandEventHeaderTriggerRecord() {
return demandEventHeaderTriggerRecord;
}
// other stuff
}

@Entity
@Table(name="pur_DemandEventHeaderTriggerRecord")
public class DemandEventHeaderTriggerRecord implements Serializable{
private Integer demandEventHeaderTRIk;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "DemandEventHeaderTRIk")
public Integer getDemandEventHeaderTRIk() {
return demandEventHeaderTRIk;
}
public boolean equals(Object other) {
//...
}
public int hashCode() {
//...
}
}

关联表定义如下:

CREATE TABLE [dbo].[pur_DemandDtl_DemandHeader](
[PromoDtlIk] [int] NULL,
[ReserveDtlIk] [int] NULL,
[DemandEventHeaderTRIk] [int] NOT NULL
) ON [PRIMARY]

部署时记录的完整堆栈跟踪如下:

2016-11-22 14:51:07,765 ERROR [org.jboss.msc.service.fail] (ServerService Thread Pool -- 84) MSC000001: Failed to start service jboss.persistenceunit."InSyncEar-11.0.0-SNAPSHOT.ear/PurchasingServices.jar#purchasingpersistence": org.jboss.msc.service.StartException in service jboss.persistenceunit."InSyncEar-11.0.0-SNAPSHOT.ear/PurchasingServices.jar#purchasingpersistence": javax.persistence.PersistenceException: [PersistenceUnit: purchasingpersistence] Unable to build Hibernate SessionFactory
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:179)
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:121)
at org.wildfly.security.manager.WildFlySecurityManager.doChecked(WildFlySecurityManager.java:667)
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1.run(PersistenceUnitServiceImpl.java:193)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
at org.jboss.threads.JBossThread.run(JBossThread.java:320)
Caused by: javax.persistence.PersistenceException: [PersistenceUnit: purchasingpersistence] Unable to build Hibernate SessionFactory
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.persistenceException(EntityManagerFactoryBuilderImpl.java:954)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:882)
at org.jboss.as.jpa.hibernate5.TwoPhaseBootstrapImpl.build(TwoPhaseBootstrapImpl.java:44)
at org.jboss.as.jpa.service.PersistenceUnitServiceImpl$1$1.run(PersistenceUnitServiceImpl.java:161)
... 7 more
Caused by: org.hibernate.persister.walking.spi.WalkingException: Association has already been visited: AssociationKey(table=pur_DemandDtl_DemandHeader, columns={DemandEventHeaderTRIk})
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.addAssociationKey(MetamodelGraphWalker.java:281)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitCollectionElements(MetamodelGraphWalker.java:257)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitCollectionDefinition(MetamodelGraphWalker.java:208)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAssociation(MetamodelGraphWalker.java:185)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributeDefinition(MetamodelGraphWalker.java:160)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributes(MetamodelGraphWalker.java:131)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitEntityDefinition(MetamodelGraphWalker.java:94)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitCollectionElements(MetamodelGraphWalker.java:264)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitCollectionDefinition(MetamodelGraphWalker.java:208)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAssociation(MetamodelGraphWalker.java:185)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributeDefinition(MetamodelGraphWalker.java:160)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributes(MetamodelGraphWalker.java:131)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitEntityDefinition(MetamodelGraphWalker.java:94)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAssociation(MetamodelGraphWalker.java:188)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributeDefinition(MetamodelGraphWalker.java:160)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitAttributes(MetamodelGraphWalker.java:131)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitEntityDefinition(MetamodelGraphWalker.java:94)
at org.hibernate.persister.walking.spi.MetamodelGraphWalker.visitEntity(MetamodelGraphWalker.java:55)
at org.hibernate.loader.plan.build.spi.MetamodelDrivenLoadPlanBuilder.buildRootEntityLoadPlan(MetamodelDrivenLoadPlanBuilder.java:39)
at org.hibernate.loader.entity.plan.AbstractLoadPlanBasedEntityLoader.<init>(AbstractLoadPlanBasedEntityLoader.java:81)
at org.hibernate.loader.entity.plan.EntityLoader.<init>(EntityLoader.java:103)
at org.hibernate.loader.entity.plan.EntityLoader.<init>(EntityLoader.java:38)
at org.hibernate.loader.entity.plan.EntityLoader$Builder.byUniqueKey(EntityLoader.java:83)
at org.hibernate.loader.entity.plan.EntityLoader$Builder.byPrimaryKey(EntityLoader.java:77)
at org.hibernate.loader.entity.plan.AbstractBatchingEntityLoaderBuilder.buildNonBatchingLoader(AbstractBatchingEntityLoaderBuilder.java:30)
at org.hibernate.loader.entity.BatchingEntityLoaderBuilder.buildLoader(BatchingEntityLoaderBuilder.java:59)
at org.hibernate.persister.entity.AbstractEntityPersister.createEntityLoader(AbstractEntityPersister.java:2254)
at org.hibernate.persister.entity.AbstractEntityPersister.createEntityLoader(AbstractEntityPersister.java:2276)
at org.hibernate.persister.entity.AbstractEntityPersister.createLoaders(AbstractEntityPersister.java:3876)
at org.hibernate.persister.entity.AbstractEntityPersister.postInstantiate(AbstractEntityPersister.java:3858)
at org.hibernate.internal.SessionFactoryImpl.<init>(SessionFactoryImpl.java:444)
at org.hibernate.boot.internal.SessionFactoryBuilderImpl.build(SessionFactoryBuilderImpl.java:444)
at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:879)
... 9 more

感谢您的宝贵时间。

最佳答案

In addition there is a 4th table which represents BOTH associations. This 4th table has 3 columns. Each column corresponds to one of the tables. Obviously in each row one of the two columns associated with the two tables has a null value.

显然您将苹果和香蕉存储在同一张表中。 JoinTable 的目的是只存储一个关系。 JoinTable 有两列,每一侧都有实体的 id(我不知道是否可以使用复合键,那么你相应地就有更多的列)。 Hibernate 应该如何处理 null 值?把他们过滤掉?或者向集合中添加一个空值?

1) do I have to do something else because there are 2 tables in a relationship with the third?

您必须将此表分成两部分。

2) is it legitimate to hold both associations in the same association table?

规范合法性:不知道。但这没有任何意义。

3) is the hierarchy of the first 2 classes problemtic?

没有。

关于java - 在 Hibernate 中,两个实体如何与第三个实体具有多对多的单向关系?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40746957/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com