jQuery in Action, 3rd edition
The moose likes Object Relational Mapping and the fly likes Hibernate Criteria can't create joins for Embedded objects Big Moose Saloon
  Search | Java FAQ | Recent Topics | Flagged Topics | Hot Topics | Zero Replies
Register / Login

Win a copy of Java Interview Guide this week in the Jobs Discussion forum!
JavaRanch » Java Forums » Databases » Object Relational Mapping
Bookmark "Hibernate Criteria can Watch "Hibernate Criteria can New topic

Hibernate Criteria can't create joins for Embedded objects

Raja Sinha

Joined: Sep 18, 2011
Posts: 1
I believe many of you must be already knowing the usage of Embedded Class which we use to define composite primary keys in an Entity class. However, it seems Hibernate Criteria is not able to read joins if I am using Embedded objects to refer to an Entity class.

Consider the following example:-

I’ve three tables A, B & AB, where AB holds relationship between A & B and hence has a composite primary key which comprises of the primary key of A & primary key of B. I represent the relationship in hibernate as below (i am using annotations):-

Entity class A.java

public class A{
private long aId;
….//other properties
private List bList; //I’ve deliberately given the name bList since using this I can get data of B.
public long getAId(){
return aId;
public void setAId(long aId){
this.aId = aId;
public List getBList(){
return bList;
public void setBList(List bList){
this.bList = bList;

Entity class B.java

public class B{
private long bId;
private String name;
….//other properties
private List aList; //I’ve deliberately given the name bList since using this I can get data of A.
public long getBId(){
return bId;
public void setId(long bId){
this.bId = bId;
public String getName(){
return name;
public void setName(String name){
this.name = name;
public List getAList(){
return aList;
public void setAList(List aList){
this.aList = aList;

Entity class AB.java

public class AB{
private AB_pk pk;
….//other properties
//Constructor to set PK object
public AB(A a, B b){
pk = new AB_pk();
public AB_pk getPk(){
return pk;
public void setPk(AB_pk pk){
this.pk = pk;

Embeddable class AB_pk.java

public class AB{
private A a;
private B b;
public AB_pk(){ } //Empty constructor – required
public A getA(){
return a;
public void setA(A a){
this.a = a;
public B getB(){
return b;
public void setB(B b){
this.b = b;

Criteria code block

Criteria criteria = session.createCriteria(A.class);
criteria.createCriteria(“bList”, “ab”, CriteriaSpecification.INNER_JOIN);
criteria.createAlias(“ab.pk”, “pk”);
criteria.createCriteria(“pk.B”, “b”, CriteriaSpecification.INNER_JOIN);
ProjectionList projections = Projections.projectionList();
projections.add(Projections.property(“b.name”), “bName”);
criteria.add(Restrictions.eq(“aId”, Long.valueOf(1)));
List list = criteria.list();

SQL Query formed by Hibernate


If you notice that it is able to identify B_NM column through the Embedded ID relationship in Projections but the inner join specified in Criteria was not added by hibernate in the SQL query generated by itself.
Does anybody know where the problem is?
I agree. Here's the link: http://aspose.com/file-tools
subject: Hibernate Criteria can't create joins for Embedded objects
It's not a secret anymore!