0
votes

I have problem using Fluent Nhibernate, I have following model. When I try to save Hotel with has new Geography I getting foreign key exception, looks like Nhibenate fails to save data in correct order, is it something I can correct via Fluent Nhibernate ?

public class Geography {
  public virtual int CityID { get; set; }
  public virtual string CountryCode { get; set; }
}

public class Hotel
{
        public virtual int HotelID { get; set; }
        public virtual Geography City { get; set; }

}

Mapping

 public class HotelMap : ClassMap<Hotel>
 {
  public HotelMap()
  {
   Id(x => x.HotelID)
                .GeneratedBy
                .Identity();             
            References(x => x.City, "CityId")
                .Cascade.All();                                               
  }

 }

 public class GeographyMap : ClassMap<Geography>
 {
  public GeographyMap()
  {
   Id(x => x.CityID);
   Map(x => x.CountryCode);
            HasMany(a => a.Hotels)
                .Cascade.All();
  }
 }

Added generated mappings

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-access="property" auto-import="true" default-cascade="none" default-lazy="true">
  <class xmlns="urn:nhibernate-mapping-2.2" mutable="true" name="Hotel" table="`Hotel`">
    <id name="HotelID" type="System.Int32">
      <column name="HotelID" />
      <generator class="assigned" />
    </id>
    <many-to-one cascade="all" class="Geography" foreign-key="HotelGeography" name="City">
      <column name="CityId" />
    </many-to-one>
  </class>
</hibernate-mapping>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2" default-access="property" auto-import="true" default-cascade="none" default-lazy="true">
  <class xmlns="urn:nhibernate-mapping-2.2" mutable="true" name="Geography" table="`Geography`">
    <id name="CityID" type="System.Int32">
      <column name="CityID" />
      <generator class="assigned" />
    </id>
    <bag cascade="all" inverse="true" name="Hotels" mutable="true">
      <key>
        <column name="HotelID" />
      </key>
      <one-to-many class="Hotel" />
    </bag>
    <property name="CountryCode" type="System.String">
      <column name="CountryCode" />
    </property>
  </class>
</hibernate-mapping>
2

2 Answers

1
votes

Try to specify identity generator for Geography class. If you want to have a database-generated unique identifier (like identity), you can accomplish that by adding .GeneratedBy.Native() to your Id(...) in GeographyMap class.