JPQL при многократном извлечении возвращает ошибку «невозможно одновременно получить несколько пакетов» - PullRequest
0 голосов
/ 13 октября 2018

Я учусь на 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?или мое отображение сущностей неверно?

1 Ответ

0 голосов
/ 13 октября 2018

Кажется, это ошибка, связанная с фреймворком.Зависит от вашей спящей версии.

Считайте эту проблему похожей на вашу ССЫЛКА

Декартово произведение

Имейте в виду, что при соединении для извлечения обоих наборов вы получите декартовопродукт обоих.Более подробную информацию о самой проблеме и ее решениях можно получить по адресу ЗДЕСЬ

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...