リレーションシップを使用したJPA-2.0クエリに関する問題で立ち往生しています。Dataset
少なくとも1つでどれEvent
を選択することはどのように可能でしょうtype = B
か?
@Entity
class Dataset {
@OneToMany(fetch = FetchType.LAZY, mappedBy = "dataset")
public List<Event> events;
}
@Entity
class Event {
@ManyToOne
@JoinColumn
public Dataset dataset;
public Type type;
}
enum Type {
A, B, C
}
私の出発点は
CriteriaBuilder _builder = em.getCriteriaBuilder();
CriteriaQuery<Dataset> _criteria = _builder.createQuery(Dataset.class);
// select from
Root<Dataset> _root = _criteria.from(Dataset.class);
_criteria.select(_root);
// apply some filter as where-clause (visitor)
getFilter().apply(
_root, _criteria, _builder, em.getMetamodel()
);
// how to add a clause as defined before?
...
これに関するアイデア。結合だけでなくサブクエリも作成しようとしましたが、どういうわけか間違ってしまい、結果として常にすべてのデータセットを取得していました。