Friday, May 6, 2011

Hibernate one to zero or one mapping

I'm trying to map a one to "zero or one" relationship in Hibernate. I think I may have found a way using a many-to-one.

class A {
  private B b;
  // ... getters and setters
}

class B {
  private A a;
}

Class A's mapping specifies:

<many-to-one name="b" class="B" 
insert="false" update="false" 
column="id" unique="true"/>

and Class B's mapping specifies:

<one-to-one name="a" class="A" constrained="true"/>

What I would like is for b to be null when no matching row for B was found in the database. So I can do this (in class A):

if (b == null)

However, it seems that b is never null.

What can I do about this?

From stackoverflow
  • Try setting lazy="false" on the many-to-one element. That should force Hibernate to try to fetch the association ("B") when the first object ("A") is loaded. The property in "A" will either be initialized with a real instance of "B" or null.

  • The answer was to add not-found="ignore" to the many-to-one statement in A:

    <many-to-one name="b" class="B" not-found="ignore" insert="false" update="false" column="id" unique="true"/>
    

    I tried simply adding lazy="false" to B as Rob H recommended, but that resulted in a HibernateObjectRetrievalFailureException everytime I loaded an A that had no B.

    See this thread for more information:

    https://forum.hibernate.org/viewtopic.php?p=2269784&sid=5e1cba6e2698ba4a548288bd2fd3ca4e

0 comments:

Post a Comment