Search code examples
javahibernatenhibernate-mapping

one to many relation with column other than Id (Primary Key)


I am trying to map two tables using hibernate one-to-many mapping. But, always it is mapping with the wrong column. Please any body help me on this.

Level4_Master [level_id (PK/Auto Increament), company_id, level_name, next_level_id, ts]
Level3_Master [level_id (PK/Auto Increament), prv_level_id, level_name, next_level_id, ts]

Above are the two tables I am using for the mapping. Here, I wanted to map column next_level_id of Level4_Master with column prv_level_id of Level3_Master. But, hibernate always mapping the column prv_level_id with level_id of Level4_Master as FK. My mapping files are:

<hibernate-mapping>
<class name="com.pojo.Level4" table="Level4_Master">
    <id name="levelId" type="java.lang.Integer">
        <column name="level_id" />
        <generator class="increment" />
    </id>
    <property name="companyId" >
        <column name="company_id" length="10" not-null="true" unique="true" />
    </property>
    <property name="levelName">
        <column name="level_name" length="20" not-null="true" unique="true" />
    </property>
    <property name="nextLevelId" type="java.lang.Integer">
        <column name="next_level_id" />
    </property>
    <set name="levelList" table="Level3_Master" inverse="true" lazy="true" fetch="select">
        <key>
            <column name="prv_level_id" not-null="true" />
        </key>
        <one-to-many class="com.pojo.Level3" />
    </set>
</class>
</hibernate-mapping>

and

<hibernate-mapping>
<class name="com.pojo.Level3" table="Level3_Master">
<id name="levelId" type="java.lang.Integer">
    <column name="level_id" />
    <generator class="increment" />
</id>
<property name="prvLevelId" >
    <column name="prv_level_id" length="10" not-null="true" unique="true" />
</property>
<property name="levelName">
    <column name="level_name" length="20" not-null="true" unique="true" />
</property>
<property name="nextLevelId" type="java.lang.Integer">
    <column name="next_level_id" />
</property>
<set name="levelList" table="Level2_Master" inverse="true" lazy="true" fetch="select">
    <key>
        <column name="prv_level_id" not-null="true" />
    </key>
    <one-to-many class="com.pojo.Level2" />
</set>
</class>
</hibernate-mapping>

and my pojo classes are like

class Level4{
  private int levelId;
  private int companyId;
  private String levelName;
  private int nextLevelId;
  private Set<Level3> levelList = new HashSet<Level3>(0); 
  private Timestamp ts;
  //getter n setter
}

class Level3{
  private int levelId;
  private int prvLevelId;
  private String levelName;
  private int nextLevelId;
  private Set<Level2> levelList = new HashSet<Level2>(0); 
  private Timestamp ts;
  //getter n setter
}

Solution

  • You need to use property-ref attribute with the property name. The property must add unique="true" in the property mapping.

    Example -

    <hibernate-mapping><class name="com.pojo.Level4" table="Level4_Master">
    <id name="levelId" type="java.lang.Integer">
        <column name="level_id" />
        <generator class="increment" />
    </id>
    <property name="companyId" >
        <column name="company_id" length="10" not-null="true" unique="true" />
    </property>
    <property name="levelName">
        <column name="level_name" length="20" not-null="true" unique="true" />
    </property>
    <property name="nextLevelId" type="java.lang.Integer" unique="true">
        <column name="next_level_id" />
    </property>
    <set name="levelList" table="Level3_Master" inverse="true" lazy="true" fetch="select">
        <key>
            <column name="prv_level_id" not-null="true" property-ref="nextLevelId"/>
        </key>
        <one-to-many class="com.pojo.Level3" />
    </set>