Я учусь на Spring Data JPA.
У меня проблема с JPQL.Я бог трех сущностей.
public class Cheat implements Serializable {
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "cheat_seq", length = 10)
private Long cheatSeq;
@OneToMany(mappedBy = "cheat", fetch=FetchType.LAZY)
private List<CheatGoodVote> goodVote;
@OneToMany(mappedBy = "cheat", fetch=FetchType.LAZY)
private List<CheatBadVote> badVote;
// skipped.
}
и другие являются сущностями, которые сопоставлены с вышеуказанной сущностью.
public class CheatGoodVote {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="vote_seq", length=10)
private Long voteSeq;
@ManyToOne(cascade=CascadeType.ALL)
@JoinColumn(name="cheat_fk", referencedColumnName="cheat_seq")
public Cheat cheat;
// ..skipped
}
Две сущности почти одинаковы друг с другом.
public class CheatBadVote {
@Id
@GeneratedValue(strategy=GenerationType.IDENTITY)
@Column(name="vote_seq", length=10)
private Long voteSeq;
@Column(name="ip_address", nullable=false)
private String ipAddress;
@Column(name="reg_date", nullable=false)
private Date regDate;
@ManyToOne(cascade=CascadeType.ALL)
@JoinColumn(name="cheat_fk", referencedColumnName="cheat_seq")
public Cheat cheat;
}
И когда я вызываю JPQL "@ Query (" ВЫБРАТЬ С ИЗ ЧИТА c СОВМЕСТНАЯ ВЫБОРКА c.goodVote СОВМЕСТНОЕ ВЫБОР c.badVote ГДЕ РАЗМЕР (c.goodVote) <=: voiceCnt ")" </strong>,
Возвращает ошибки:
Caused by: org.hibernate.loader.MultipleBagFetchException: cannot simultaneously fetch multiple bags: [com.aibiigae1221.skyQuiz.data.entity.Cheat.goodVote, com.aibiigae1221.skyQuiz.data.entity.Cheat.badVote]
at org.hibernate.loader.BasicLoader.postInstantiate(BasicLoader.java:75) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.loader.hql.QueryLoader.<init>(QueryLoader.java:106) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:210) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:141) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:115) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:77) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:153) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:553) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
at org.hibernate.internal.AbstractSharedSessionContract.createQuery(AbstractSharedSessionContract.java:662) ~[hibernate-core-5.2.17.Final.jar:5.2.17.Final]
... 103 common frames omitted
Я хочу получить Cheat , CheatGoodVote , CheatBadVote дать право вместе.Ошибка происходит от проблемы jpql?или мое отображение сущностей неверно?