Как с помощью NHibernate добавить дочерний объект при обновлении родительского объекта? - PullRequest
0 голосов
/ 27 мая 2010

У меня есть простые отношения Родитель / Дитя между объектом Person и объектом Address. Объект Person существует в БД. После выполнения Get on the Person я добавляю новый объект Address в список подобъектов Address родительского объекта и делаю некоторые другие обновления для объекта Person. Наконец, я делаю обновление объекта Person. В окне трассировки SQL я вижу обновление объекта Person для таблицы Person и вставку записи Address в таблицу Address.

Проблема заключается в том, что после выполнения обновления AddressId (первичный ключ объекта Address) по-прежнему имеет значение 0, то есть значение по умолчанию при первой инициализации объекта Address. Я проверил, что когда я делаю Add, это значение установлено правильно. Является ли это известной проблемой при попытке добавления подобъектов в рамках обновления NHibernate? Пример кода и файлы сопоставления ниже

Спасибо

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"> 
  <class name="BusinessEntities.Wellness.Person,BusinessEntities.Wellness" table="Person" lazy="true" dynamic-insert="true" dynamic-update="false"> 
    <id name="Personid" column="PersonID" type="int"> 
      <generator class="native" /> 
    </id> 
    <version type="binary" generated="always" name="RecordVersion" column="`RecordVersion`"/> 
    <property type="int" not-null="true" name="Customerid" column="`CustomerID`" /> 
    <property type="AnsiString" not-null="true" length="9" name="Ssn" column="`SSN`" /> 
    <property type="AnsiString" not-null="true" length="30" name="FirstName" column="`FirstName`" /> 
    <property type="AnsiString" not-null="true" length="35" name="LastName" column="`LastName`" /> 
    <property type="AnsiString" length="1" name="MiddleInitial" column="`MiddleInitial`" /> 
    <property type="DateTime" name="DateOfBirth" column="`DateOfBirth`" /> 
    <bag name="PersonAddresses" inverse="true" lazy="true" cascade="all"> 
      <key column="PersonID" /> 
      <one-to-many class="BusinessEntities.Wellness.PersonAddress,BusinessEntities.Wellness" / 
    </bag> 
  </class> 
</hibernate-mapping>

<hibernate-mapping xmlns="urn:nhibernate-mapping-2.2"> 
  <class name="BusinessEntities.Wellness.PersonAddress,BusinessEntities.Wellness" table="PersonAddress" lazy="true" dynamic-insert="true" dynamic-update="false"> 
    <id name="PersonAddressId" column="PersonAddressID" type="int"> 
      <generator class="native" /> 
    </id> 
    <version type="binary" generated="always" name="RecordVersion" column="`RecordVersion`" /> 
    <property type="AnsiString" not-null="true" length="1" name="AddressTypeid" column="`AddressTypeID`" /> 
    <property type="AnsiString" not-null="true" length="60" name="AddressLine1" column="`AddressLine1`" /> 
    <property type="AnsiString" length="60" name="AddressLine2" column="`AddressLine2`" /> 
    <property type="AnsiString" length="60" name="City" column="`City`" /> 
    <property type="AnsiString" length="2" name="UsStateId" column="`USStateID`" /> 
    <property type="AnsiString" length="5" name="UsPostalCodeId" column="`USPostalCodeID`" /> 
    <many-to-one name="Person" cascade="none" column="PersonID" /> 
  </class> 
</hibernate-mapping>


        Person newPerson = new Person(); 
        newPerson.PersonName = "John Doe"; 
        newPerson.SSN = "111111111"; 
        newPerson.CreatedBy = "RJC"; 
        newPerson.CreatedDate = DateTime.Today; 
        personDao.AddPerson(newPerson); 
        Person updatePerson = personDao.GetPerson(newPerson.PersonId); 

        updatePerson.PersonAddresses = new List<PersonAddress>(); 
        PersonAddress addr = new PersonAddress(); 
        addr.AddressLine1 = "1 Main St"; 
        addr.City = "Boston"; 
        addr.State = "MA"; 
        addr.Zip = "12345"; 
        updatePerson.PersonAddresses.Add(addr); 
        personDao.UpdatePerson(updatePerson); 
        int addressID = updatePerson.PersonAddresses[0].AddressId; 

1 Ответ

0 голосов
/ 27 мая 2010

Попробуйте:

    updatePerson.PersonAddresses = new List<PersonAddress>(); 
    PersonAddress addr = new PersonAddress(); 
    addr.AddressLine1 = "1 Main St"; 
    addr.City = "Boston"; 
    addr.State = "MA"; 
    addr.Zip = "12345"; 
    updatePerson.PersonAddresses.Add(addr);
    addr.Person = updatePerson

Обычной практикой является предоставление методов добавления и удаления для управления коллекциями, например

public void AddAddress(Address addr)
{
    PersonAddresses.Add(addr);
    addr.Person = this;
}
...