使用join进行Querydsl实体继承查询

时间:2015-02-25 11:47:22

标签: java hibernate postgresql jpa querydsl

我有三个实体。用户(父母)

@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@DiscriminatorColumn(name = "user_type")
@Table(name = "userinfo")
@SequenceGenerator(name = "userInfoUserIdSeq", initialValue = 1, allocationSize = 100, sequenceName = "userinfo_user_id_seq")
public abstract class UserInfo {

public static final String EDITOR = "E";
public static final String TALENT = "T";

@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "userInfoUserIdSeq")
@Column(name = "user_id")
private Long id;
...

编辑器(子)

@Entity
@DiscriminatorValue(UserInfo.EDITOR)
@Table(name = "editors")
public class Editor extends UserInfo { ....

记者(子)

@Entity
@DiscriminatorValue(UserInfo.TALENT)
@Table(name = "talent")
public class Talent extends UserInfo { .....

我在querydsl

上写了以下不能正常工作的查询
    QUserInfo userInfo = QUserInfo.userInfo;
    text = "%"  + text + "%";
    QTalent talent = QTalent.talent;
    QEditor editor = QEditor.editor;
    SearchResults<UserInfo> results = query.from(userInfo).leftJoin(userInfo, talent._super)
            .leftJoin(userInfo, editor._super).where( .....

我有以下堆栈跟踪:

     at            com.mysema.query.jpa.impl.AbstractJPAQuery.createQuery(AbstractJPAQuery.java:127)
    at com.mysema.query.jpa.impl.AbstractJPAQuery.listResults(AbstractJPAQuery.java:261)
    at com.washpost.talent.dao.implementation.UserInfoDaoImpl.findAllUsersByNamesAndEmails(UserInfoDaoImpl.java:33)
    ... 113 more
Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: Path expected for join! [select count(userInfo)
from com.washpost.talent.model.UserInfo userInfo
  left join treat(userInfo as Talent) as talent
  left join treat(userInfo as Editor) as editor
where ....

我无法理解为什么我的联接不起作用

3 个答案:

答案 0 :(得分:0)

不能没有看到整个查询。

但通常你不会加入JPA中的继承表。 如果您想要所有用户(包括记者,编辑......),您只需运行Select U from User u

如果您只需要记者查询:select u From Journalist U;

JPA会在需要时将其转换为联接(以便您可以将继承类型更改为单个表,并且您的查询仍然有效)

答案 1 :(得分:0)

在JPQL中,你可以加入属性,但不能像你尝试的那样加入鉴别表。但是如果你能描述一下你需要的信息会很有帮助。

答案 2 :(得分:0)

没有必要进行左连接。正如您已经完成了类“ @Inheritance(strategy = InheritanceType.JOINED)”中的映射一样。 因此,当您进行查询时,将使用以下方式自动完成连接:

        UserInfo userInfo = new UserInfo ("userInfo");
        QTalent talent = userInfo.as(QTalent.class);
        QEditor editor = userInfo.as(QEditor.class);

Documentation about Inheritance

References: Simple Example QueryDsl