【发布时间】:2012-04-15 09:35:27
【问题描述】:
我有一个有趣的休眠问题,模型如下所示:
@NamedQueries({
@NamedQuery(name = "A.test", query = "SELECT DISTINCT a FROM A a LEFT JOIN FETCH a.pk.b WHERE a.pk.b.pk.c.id = :cId AND a.pk.b.pk.d.id = :dId")
})
@Entity
@Table(name = "AT")
public class A implements Serializable {
@EmbeddedId
private APK pk;
}
@Embeddable
public class APK implements Serializable {
@ManyToOne
@JoinColumns({@JoinColumn(name = "***", referencedColumnName = "***"),
@JoinColumn(name = "***", referencedColumnName = "***")
})
private B b;
}
@Entity
@Table(name = "BT")
public class B implements Serializable {
@EmbeddedId
private BPK pk;
}
@Embeddable
public class APK implements Serializable {
@ManyToOne
@JoinColumn(name = "***", referencedColumnName = "***")
private C c;
@ManyToOne
@JoinColumn(name = "***", referencedColumnName = "***")
private D d;
}
问题在于命名查询会进行额外的 SQL 查询... 问题是什么? 谢谢!
【问题讨论】: