在查询中强制转换实体

时间:2015-03-05 15:46:14

标签: jpa jpql

我正在寻找一种在jpql查询中强制转换实体的方法。

示例:

@Entity
class Topic {
  @OneToMany
  List<AbstractMessage> messages;
}

@Entity
@Inheritance(strategy = InheritanceType.JOINED)
abstract class AbstractMessage {
   String content;
}

@Entity
class MessageType1 extends AbstractMessage {
   String att1;
}

@Entity
class MessageType2 extends AbstractMessage {
   Integer att2;
}

我正在尝试收集所有主题,其中一条或多条消息的类型为MessageType2且att2 = 1。

以下是我作为jpql查询的建议:

select t from Topic t left outer join t.messages on (Type(t) = MessageType2)
where t.att2 = 1 

我不认为此查询有效,因为JPA不加入MessageType2表。

有没有办法做到这一点,或者我必须进行原生查询?

谢谢!

2 个答案:

答案 0 :(得分:4)

您可以模拟CAST: http://en.wikibooks.org/wiki/Java_Persistence/Querying#Joining.2C_querying_on_a_OneToMany_relationship

SELECT t FROM Topic t JOIN t.messages m, MessageType2 y WHERE m = y AND y.att2 = 1 

答案 1 :(得分:4)

清洁解决方案是使用JPA 2.1 TREAT

SELECT t FROM Topic t JOIN TREAT(t.messages AS MessageType2) m WHERE m.att2 = 1

http://hantsy.blogspot.cz/2013/12/jpa-21-treat.html