【问题标题】:JPQL multiple join fetch returns error "cannot simultaneously fetch multiple bags"JPQL 多连接提取返回错误“无法同时提取多个包”
【发布时间】:2019-03-18 07:59:28
【问题描述】:

我正在学习 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("SELECT c FROM Cheat c JOIN FETCH c.goodVote JOIN FETCH c.badVote WHERE SIZE(c.goodVote) ,

它返回错误:

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

我想获得 CheatCheatGoodVoteCheatBadVote 实体。 错误来自jpql问题吗?还是我的实体映射错了?

【问题讨论】:

标签: hibernate jpa jpql


【解决方案1】:

这似乎是框架相关的错误。取决于你的休眠版本。

考虑一下这个问题,看起来像你的LINK

笛卡尔积

请注意,加入获取两个集合后,您最终会得到 cartesian product 两者。有关问题本身和解决方案的更多信息,请转到HERE

【讨论】:

    猜你喜欢
    • 2011-11-24
    • 2015-01-26
    • 2011-12-25
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-02-18
    • 2015-02-16
    相关资源
    最近更新 更多