I want to use criteria to make the following query. I have an Entity with EmbeddedId defined:
@Entity
@Table(name=\"TB_IN
You need to use path navigation to access the attribute(s) of the Embeddable. Here is an example from the JPA 2.0 specification (using the static metamodel):
6.5.5 Path Navigation
...
In the following example,
ContactInfois an embeddable class consisting of an address and set of phones.Phoneis an entity.CriteriaQueryq = cb.createQuery(Vendor.class); Root emp = q.from(Employee.class); Join phone = emp.join(Employee_.contactInfo).join(ContactInfo_.phones); q.where(cb.equal(emp.get(Employee_.contactInfo) .get(ContactInfo_.address) .get(Address_.zipcode), "95054")) .select(phone.get(Phone_.vendor)); The following Java Persistence query language query is equivalent:
SELECT p.vendor FROM Employee e JOIN e.contactInfo.phones p WHERE e.contactInfo.address.zipcode = '95054'
So in your case, I think you'll need something like this:
criteriaBuilder.equal(entity.get("id").get("clase"), "Referencia 111")
Update: I've tested the provided entities with Hibernate EntityManager 3.5.6 and the following query:
CriteriaBuilder builder = em.getCriteriaBuilder();
CriteriaQuery criteria = builder.createQuery(Interfase.class);
Root interfaseRoot = criteria.from(Interfase.class);
criteria.select(interfaseRoot);
criteria.where(builder.equal(interfaseRoot.get("id").get("clase"),
"Referencia 111"));
List interfases = em.createQuery(criteria).getResultList();
runs fine and generates the following SQL:
17:20:26.893 [main] DEBUG org.hibernate.SQL -
select
interfase0_.CLASE as CLASE31_
from
TB_INTERFASES interfase0_
where
interfase0_.CLASE=?
17:20:26.895 [main] TRACE org.hibernate.type.StringType - binding 'Referencia 111' to parameter: 1
Works as expected.