Коллекция NHibernate не загружается с данными, но данные вставляются в базу данных - PullRequest
0 голосов
/ 26 февраля 2010

Не уверен, что я делаю здесь неправильно с NHibernate. У меня есть два файла сопоставления, сопоставленные с двумя таблицами. Я могу вставить данные через сопоставление в базу данных, но вызов приведенного ниже кода возвращает 0, хотя я вижу дочернюю строку, заполненную в таблице с правильным внешним ключом. Это ленивая проблема с загрузкой? Спасибо.

var result = session.Get<AnnualReport>(annualReport.ReportID);
Assert.AreEqual(result.MonthlyReports.Count, 1);  

Вот мои файлы сопоставления.

Годовой отчетный класс

<joined-subclass name="AnnualReport" extends="Report" table="AnnualReports" >  

<key column="ReportID"/>

<property name="MonthlySendDate" /> 

<bag name="MonthlyReports" lazy="true" inverse="true">
  <key column="ReportID" />
  <one-to-many class="MonthlyReport"/>
</bag>

<many-to-one name="Client" column="ClientID" not-null="true" /></joined-subclass>

Ежемесячный отчетный класс

 <joined-subclass name="MonthlyReport" extends="Report" table="MonthlyReports">

<key column="ReportID"/>
<property name="SentDate" />

<many-to-one name="AnnualReport" class="AnnualReport" column="AnnualReportID"  not-null="true"/>

<bag name="MarketReports" cascade="all">
  <key column="MonthlyReportID" />
  <one-to-many class="MarketReport"/>
</bag>

1 Ответ

0 голосов
/ 26 февраля 2010

Спасибо за ваш ответ, Стив, мне все же удалось это выяснить. Неверное сопоставление внешнего ключа. Ниже исправлена ​​проблема, и теперь коллекция загружается.

<bag name="MonthlyReports" lazy="true" inverse="true">
  <key column="AnnualReportID" />
  <one-to-many class="MonthlyReport"/>
</bag>
...