web-dev-qa-db-fra.com

Critère JPA Requête distincte

J'essaie d'écrire une requête de critères distincts en utilisant:

CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<RuleVar> query = builder.createQuery(RuleVar.class);
Root<RuleVar> ruleVariableRoot = query.from(RuleVar.class);
query.select(ruleVariableRoot.get("foo").<String>get("foo")).distinct(true);

Basé sur l'exemple dans le javadoc pour CriteriaQuery.select ()

CriteriaQuery<String> q = cb.createQuery(String.class);
 Root<Order> order = q.from(Order.class);
 q.select(order.get("shippingAddress").<String>get("state"));

Cependant, cela me donne une erreur:

The method select(Selection<? extends RuleVar>) in the type CriteriaQuery<RuleVar> is not applicable for the arguments (Path<String>)

Quelqu'un peut-il indiquer ce que je fais mal? Ou comment obtenir un objet Selection à partir d'un chemin?

22
Greg

J? ai compris. Le problème était que mon CriteraQuery devait être de type String. Cela marche:

CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery<String> query = builder.createQuery(String.class);
Root<RuleVar> ruleVariableRoot = query.from(RuleVar.class);
query.select(ruleVariableRoot.get(RuleVar_.varType)).distinct(true);
55
Greg